我有这个域名:
public class GenClass<T> { }
public class Type1 { }
public class Type2 { }
public class GenType1 : GenClass<Type1> { }
public class GenType2 : GenClass<Type1> { }
public class GenType3 : GenClass<Type2> { }
public class GenType4 : GenClass<string> { }
public class GenType5 : GenClass<int> { }
这个逻辑:
public class SomeClass {
public void Add<T>(GenClass<T> t) { }
}
这个消费者:
public class Consumer {
public void Method() {
var some = new SomeClass();
some.Add(new GenType1());
some.Add(new GenType2());
some.Add(new GenType3());
some.Add(new GenType4());
some.Add(new GenType5());
}
}
但是,我没有创建单独的每个
GenType(n)
的方法,而是创建了这样的方法:public void AddFromAssembly<TAssembly>(SomeClass some, Type baseType) {
var list = typeof(TAssembly).Assembly.GetTypes()
.Where(t => baseType.IsAssignableFrom(t)
&& !baseType.Equals(t))
.ToList();
list.ForEach(type => {
var ctor = type.GetConstructor(BindingFlags.Instance | BindingFlags.Public, null,
Type.EmptyTypes, null);
var obj = ctor.Invoke(new object[] { });
some.Add(obj); //????
});
}
并想这样称呼它:
public class Consumer {
public void Method() {
var some = new SomeClass();
AddFromAssembly<GenType1>(some, typeof(GenClass<>));
}
}
但是
some.Add
方法是通用方法,而ctor.Invoke
方法返回object
。您有解决这个问题的想法吗?提前致谢。
更新问题不完整,我已解决。感谢您的审查。
最佳答案
要么这样做:
Add<object>(obj); //this will work with T typed as object
要么:
typeof(Some).GetMethod("Add").MakeGenericMethod(new [] { typeof(obj.GetType()).Invoke(some, new [] { obj });
反射版本将在运行时为T使用obj的确切类型。
关于c# - C#反射(reflection):如何使用“对象”作为“类型参数”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10436905/