class GenericTypeReflection
{
static void Main()
{
string listTypeName = "System.Collections.Generic.List`1";
Type defByName = Type.GetType(listTypeName);
Type closedByName = Type.GetType(listTypeName + "[System.String]");
Type closedByMethod = defByName.MakeGenericType(typeof(string));
Type closedByTypeof = typeof(List<string>);
Console.WriteLine(closedByMethod == closedByName);
Console.WriteLine(closedByName == closedByTypeof);
Type defByTypeof = typeof(List<>);
Type defByMethod = closedByName.GetGenericTypeDefinition();
Console.WriteLine(defByMethod == defByName);
Console.WriteLine(defByName == defByTypeof);
}
}证明无论怎样获取对一个特定类型对象的引用,都只涉及一个这样的对象
GetGenericTypeDefinition 作用于已构造的类型 获取它的泛型类型定义
MakeGenericType 作用于泛型类型定义 返回一个已构造类型
输出
True
True
True
True
本文通过一个C#代码示例介绍了如何使用反射来处理泛型类型。演示了通过不同方式获取泛型类型和其定义的过程,并验证了这些方式是否指向同一个类型对象。

547

被折叠的 条评论
为什么被折叠?



