动态代理玩不明白?别紧张,你只是缺少这个demo( 三 )

?get方法核心代码解释获取一级和二级键 。
//根据类加载器计算一级键 cacheKey=f(loader);Object cacheKey = CacheKey.valueOf(key, refQueue);?//根据接口计算二级键 subKey=g(interfaces);Object subKey = Objects.requireNonNull(subKeyFactory.apply(key, parameter));?注意这里的subKeyFactory是Proxy初始化WeakCache类对象proxyClassCache时的入参new KeyFactory();KeyFactory是Proxy的内部类 。 不妨进入apply简单看一下:@Overridepublic Object apply(ClassLoader classLoader, Class[] interfaces) {switch (interfaces.length) {case 1: return new Key1(interfaces[0]); // the most frequentcase 2: return new Key2(interfaces[0], interfaces[1]);case 0: return key0;default: return new KeyX(interfaces);}}?循环 接下来是一个while循环 , 第一次循环前factory和supplier都为null, 所以循环体内只是做了一些初始化的工作 , 并将factory赋值给了supplier(Factory类是WeakCache的内部类 , 且继承了Supplier类) 。 第二次循环时 , 执行V value = http://kandian.youth.cn/index/supplier.get() , 实际上就是调用factory.get()方法获取动态代理类的Class实例。 factory.get()方法方法完整代码如下:
@Overridepublic synchronized V get() { // serialize access// re-checkSupplier supplier = valuesMap.get(subKey);if (supplier != this) {// something changed while we were waiting:// might be that we were replaced by a CacheValue// or were removed because of failure ->// return null to signal WeakCache.get() to retry// the loopreturn null;}// else still us (supplier == this)?// create new valueV value = http://kandian.youth.cn/index/null;try {value = Objects.requireNonNull(valueFactory.apply(key, parameter));} finally {if (value == null) { // remove us on failurevaluesMap.remove(subKey, this);}}// the only path to reach here is with non-null valueassert value != null;?// wrap value with CacheValue (WeakReference)CacheValue cacheValue = http://kandian.youth.cn/index/new CacheValue<>(value);?// try replacing us with CacheValue (this should always succeed)if (valuesMap.replace(subKey, this, cacheValue)) {// put also in reverseMapreverseMap.put(cacheValue, Boolean.TRUE);} else {throw new AssertionError("Should not reach here");}?// successfully replaced us with new CacheValue -> return the value// wrapped by itreturn value;}?第4行代码Supplier supplier = valuesMap.get(subKey)通过subKey获取方才的supplier也就是factory 。 然后在第18行调用了valueFactory.apply方法创建动态代理类并将结果赋值给变量value 。valueFactory是初始化WeakCache对象调用构造方法时传入的参数 即Prxoy的内部类ProxyClassFactory对象 。
ProxyClassFactory类进入apply方法
public Class apply(ClassLoader loader, Class[] interfaces) {Map, Boolean> interfaceSet = new IdentityHashMap<>(interfaces.length);for (Class intf : interfaces) {/** Verify that the class loader resolves the name of this* interface to the same Class object.*/Class interfaceClass = null;try {interfaceClass = Class.forName(intf.getName(), false, loader);} catch (ClassNotFoundException e) {}if (interfaceClass != intf) {throw new IllegalArgumentException(intf + " is not visible from class loader");}/** Verify that the Class object actually represents an* interface.*/if (!interfaceClass.isInterface()) {throw new IllegalArgumentException(interfaceClass.getName() + " is not an interface");}/** Verify that this interface is not a duplicate.*/if (interfaceSet.put(interfaceClass, Boolean.TRUE) != null) {throw new IllegalArgumentException("repeated interface: " + interfaceClass.getName());}}?String proxyPkg = null;// package to define proxy class inint accessFlags = Modifier.PUBLIC | Modifier.FINAL;?/** Record the package of a non-public proxy interface so that the* proxy class will be defined in the same package. Verify that* all non-public proxy interfaces are in the same package.*/for (Class