c# – 如何使用反射从泛型中返回所有类的子类,而不提供特定的泛型类型

前端之家收集整理的这篇文章主要介绍了c# – 如何使用反射从泛型中返回所有类的子类,而不提供特定的泛型类型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用反射编写一个方法来返回所有类,这些类是使用泛型的类的子类,而不受泛型类型的限制.例如,在EF中我想找到所有的映射类.这些类的设置如下:
public class clientMap : EntityTypeConfiguration<Client> {}

我想找到我的程序集中的所有类,它们是EntityTypeConfiguration< T>的子类,而没有具体指定Client作为T.我想在我的应用程序中为所有类返回实体类型配置,而不对其进行硬编码.

如果没有泛型,我会循环遍历程序集中的类型,检查是否type.IsSubclassOf(typeof(BaseClass)),但是我不知道在处理泛型时如何做到这一点.

解决方法

我相信你想要这样的东西:
static class TypeExtensions {
    public static bool IsDerivedFromOpenGenericType(
        this Type type,Type openGenericType
    ) {
        Contract.Requires(type != null);
        Contract.Requires(openGenericType != null);
        Contract.Requires(openGenericType.IsGenericTypeDefinition);
        return type.GetTypeHierarchy()
                   .Where(t => t.IsGenericType)
                   .Select(t => t.GetGenericTypeDefinition())
                   .Any(t => openGenericType.Equals(t));
    }

    public static IEnumerable<Type> GetTypeHierarchy(this Type type) {
        Contract.Requires(type != null);
        Type currentType = type;
        while (currentType != null) {
            yield return currentType;
            currentType = currentType.BaseType;
        }
    }
}

这些测试通过:

class Foo<T> { }
class Bar : Foo<int> { }
class FooBar : Bar { }

[Fact]
public void BarIsDerivedFromOpenGenericFoo() {
    Assert.True(typeof(Bar).IsDerivedFromOpenGenericType(typeof(Foo<>)));
}

[Fact]
public void FooBarIsDerivedFromOpenGenericFoo() {
    Assert.True(typeof(FooBar).IsDerivedFromOpenGenericType(typeof(Foo<>)));
}

[Fact]
public void StringIsNotDerivedFromOpenGenericFoo() {
    Assert.False(typeof(string).IsDerivedFromOpenGenericType(typeof(Foo<>)));
}

猜你在找的C#相关文章