为什么在java中的“超级类型令牌”模式中需要匿名类
在Neal Gafter的“超类型令牌”模式(http://gafter.blogspot.com/2006/12/super-type-tokens.html)中,一个匿名对象用于传递参数化类型:
class ReferenceType<T>{}
/* anonymous subclass of "ReferenceType" */
ReferenceType<List<Integer>> referenceType = new ReferenceType<List<Integer>>(){
};
Type superClass = b.getClass().getGenericSuperclass();
System.out.println("super type : " + superClass);
Type genericType = ((ParameterizedType)superClass).getActualTypeArguments()[0];
System.out.println("actual parameterized type : " + genericType);
然后结果是:
super type : com.superluli.test.ReferenceType<java.util.List<java.lang.Integer>>
actual parameterized type : java.util.List<java.lang.Integer>
我的问题是,匿名对象“referenceType”做了什么魔术来使它工作?如果我定义了“ReferenceType”的显式子类,并使用它而不是匿名样式,它就不会像预期的那样。
class ReferenceType<T>{}
class ReferenceTypeSub<T> extends ReferenceType<T>{}
/* explicitly(or, named) defined subclass of "ReferenceType" */
ReferenceType<List<Integer>> b = new ReferenceTypeSub<List<Integer>>();
Type superClass = b.getClass().getGenericSuperclass();
System.out.println("super type : " + superClass);
Type genericType = ((ParameterizedType)superClass).getActualTypeArguments()[0];
System.out.println("actual parameterized type : " + genericType);
结果是:
super type : com.superluli.test.ReferenceType<T>
actual parameterized type : T