Classwo***ng工具箱: 分析泛型数据结构 - 编程入门网
s.length != m_types.length) {
throw new IllegalArgumentException("Wrong number of
parameter types");
}
// build substitution map for type parameters
HashMap<String,TypeDescription> tmap =
new HashMap<String,TypeDescription>();
for (int i = 0; i < m_typeParameters.length; i++) {
TypeDescription type = m_types[i];
if (type == null) {
type = m_upperBounds[i];
}
tmap.put(m_typeParameters[i], type);
}
// handle the actual type substitutions
m_fields = new FieldDescription[m_genericFields.length];
for (int i = 0; i < m_genericFields.length; i++) {
FieldDescription field = m_genericFields[i];
if (field.getType() == null) {
String sig = field.getSignature();
TypeDescription desc =
m_typeDirectory.getMappedSignatureInstance(sig, tmap);
m_fields[i] = new FieldDescription(field.getName(), sig, desc);
} else {
m_fields[i] = field;
}
}
}
return m_fields;
}
public String toString() {
return m_name;
}
}
}
Classworking工具箱: 分析泛型数据结构(5)时间:2011-10-16 IBM Dennis SosnoskiTypeDirectory 类中第一个遗漏的部分是 m_templateMap 字段。这个哈希映射把没有参数类型的泛型 类的字段描述符字符串与这个类的 GenericTemplate 关联起来。GenericTemplate 实例包含类的基本类 型参数信息,还有为类定义的字段的数组。不是泛型引用的字段都在泛型模型定义的时候完全定义;是 泛型引用的字段则保留作为签名,留在以后进行填充。内部的 DescriptionBuilderVisitor 类实现从泛 型类的二进制表示实际收集这个模板信息的实际 ASM 处理工作。 清单 2 的 TypeDirectory 类遗漏的其他部分是 getSignatureInstance() 和 getMappedSignatureInstance() 方法以及后一个方法使用的内部 SignatureDecompositionVisitor 类的 完整代码。getSignatureInstance() 方法实际地构建新的泛型类模板,然后为参数类型的具体列表实例 化这些模板。实例化过程由 GenericTemplate 的内部 ParameterizedClassDescription 类的构造函数方 法设置,但是会推迟到这个 TypeDescription 子类第一次请求字段列表的时候。 为什么要在 ParameterizedClassDescription 类中推迟替换的处理?还是因为递归的问题。如果没有 延迟处理,就会发生这样的情况:仅仅对泛型模板的基本字段定义进行处理,就会引起对这个模板的同一 版本的实例化。 TypeDirectory 类的 getMappedSignatureInstance() 方法接受字段签名和一个映射(映射中保存类 型参数变量名称到实际参数类型的映射),这个方法使用内部 SignatureDecompositionVisitor 类的实 例来处理签名,并在看到类型参数变量的时候执行替换。签名完全处理之 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |