今天我试图做一些约定测试,并在程序集中获取所有类型(通过调用
Assembly.GetTypes()
),当我偶然发现一些东西时:
System.RuntimeType:[First.Namespace.FirstClass]
每当我尝试将该类型与
typeof(FirstClass)
进行比较时,它们都不相等。因此,当我尝试查找包含 FirstClass
作为泛型参数的所有类型时,我没有找到任何类型。
System.RuntimeType
和System.Type
有什么区别?
有什么办法可以解决我的问题吗?
System.RuntimeType
是一个具体类,派生自抽象基类 System.Type
。由于 System.RuntimeType
不是公开的,因此您通常会遇到它的实例 System.Type
。
当您尝试获取对象的类型并错误地在代表第一个对象类型的另一个对象上调用
GetType()
而不是直接使用该对象时,可能会出现混乱。然后,当调用它的对象表示类型时,Type.ToString()
将返回"System.RuntimeType"
:
string str = string.Empty;
Type strType = str.GetType();
Type strTypeType = strType.GetType();
strType.ToString(); // returns "System.string"
strTypeType.ToString(); // returns "System.RuntimeType"
例如,在这篇博文中,有人试图获取数据库中列的类型,执行如下操作:
object val = reader.GetFieldType(index);
Type runtimeType = val.GetType();
PropertyInfo propInfo = runtimeType.GetProperty("UnderlyingSystemType");
Type type = (Type)propInfo.GetValue(val, null);
由于
val
已经是一个 Type
对象,val.GetType()
将返回表示类型 Type
的另一个 System.RuntimeType
对象,因为这是用于表示原始类型对象的具体类型。然后,该博客文章展示了一些不必要的反射技巧,以获取原始类型对象的类型,而实际上所需的只是:
Type type = reader.GetFieldType(index) as Type;
因此,如果您的
Type
对象报告它代表 System.RuntimeType
,请确保您没有意外地在已有的类型上调用 GetType()
。
来自 Thomas Danecker对System.Type 和 System.RuntimeType 的不同回答:
System.Type 是一个抽象基类。 CLR 有它的具体内容 内部类型的实现 系统.运行时类型。因为这 typeof(string).GetType() 返回一个 RuntimeType 但 typeof(Type) 返回一个 正常类型。使用 .Equals 方法 实际上是一个 object.ReferenceEquals 返回 false。为了得到 期待结果,您可以使用 类型.IsInstanceOfType(元素)。这 如果元素是,也将返回 true 派生类型。如果您想检查 对于确切的类型,返回值 您的方法的 false 是理想的 结果。您还可以使用 检查类型(数组类型, Type.GetType("System.RuntimeType")) 到 检查 RuntimeType。
简而言之...
"".GetType().ToString() == "System.String"
"".GetType().GetType().ToString() == "System.RuntimeType"
我现在的想法是,
System.Type
是运行时表示对象类型请求结果的类型的基类型,即System.RuntimeType
。因此,当您请求对象的类型(如 "".GetType()
)时,返回的 System.Type
实例是它的后代 System.RuntimeType
。事实上,人们应该期望 typeof(System.Type).GetType()
也应该是 System.RuntimeType
,但我认为该框架专门阻止了这种......对称性。