class myClass1
{
public string obj1;
public string obj2;
}
class myClass2
{
public myClass1[] fArray = new myClass1[1];
public string str;
}
class Program
{
static void Main(string[] args)
{
string mytype = "ConsoleApp3.myClass2";
Type type = Type.GetType(mytype);
object myObj = Activator.CreateInstance(type);
FieldInfo fi = type.GetField("fArray");
Type type2 = fi.FieldType.GetElementType();
object newObj;
IList list = (IList)Activator.CreateInstance(typeof(List<>).MakeGenericType(fi.GetValue(myObj).GetType().GetElementType()));
{
newObj = Activator.CreateInstance(type2);
FieldInfo fi2 = type2.GetField("obj1");
fi2.SetValue(newObj, "some txt1");
FieldInfo fi3 = type2.GetField("obj2");
fi3.SetValue(newObj, "some txt2");
list.Add(newObj);
}
{
newObj = Activator.CreateInstance(type2);
FieldInfo fi2 = type2.GetField("obj1");
fi2.SetValue(newObj, "some txt1");
FieldInfo fi3 = type2.GetField("obj2");
fi3.SetValue(newObj, "some txt2");
list.Add(newObj);
}
fi.SetValue(myObj, list.Cast<myClass1>().ToArray());
上面的代码工作正常。在我的用例中,在编译时不知道“ myClass1”。我在运行时以字符串形式接收myClass1的类型。
如何使用反射将列表转换为myClass1类型的数组?
fi.SetValue(myObj, list.Cast<???>().ToArray());
您也可以创建通用方法:
让我们为元素类型创建一个局部变量,以便我们可以重用它。
var elementType = fi.GetValue(myObj).GetType().GetElementType();
...
从linq可枚举类中获取cast方法和array方法。
var castMethod = typeof(System.Linq.Enumerable).GetMethod("Cast").MakeGenericMethod(elementType);
var arrayMethod = typeof(System.Linq.Enumerable).GetMethod("ToArray").MakeGenericMethod(elementType);
以null作为静态方法的第一个参数调用方法。
var casted = castMethod.Invoke(null, new[] { list });
var array = arrayMethod.Invoke(null, new[] { casted });
fi.SetValue(myObj, array);
这样做可能会有更聪明的方法,但这可能会让您入门。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句