如何在使用 Reflection.SetValue 时提供转换
本文关键字:转换 SetValue Reflection | 更新日期: 2023-09-27 18:35:03
我有一个假装成 int 的类,所以它重载了各种运算符;
public class MyId
{
int value;
public virtual int Value
{
get { return this.value; }
set { this.value = value; }
}
public MyId(int value)
{
this.value = value;
}
public static implicit operator MyId(int rhs)
{
return new MyId(rhs);
}
public static implicit operator int(MyId rhs)
{
return rhs.Value;
}
}
但是,当我使用这样的代码时
PropertyInfo.SetValue(myObj, 13, null)
OR
MyId myId = 13;
int x = Convert.ToInt32(myId);
IConvertible iConvertible = x as IConvertible;
iConvertible.ToType(typeof(MyId), CultureInfo.CurrentCulture);
我得到无效的投射。我很困惑,这两个调用似乎都试图在 int 上调用 convert,这将失败,因为 int 不理解 MyId 类型(即使所有赋值运算符都在那里(。对此有什么解决方法的任何想法,我确定我一定错过了一些愚蠢的东西?
隐式转换是 C# 构造,无法通过反射获得。此外,通过反射设置字段或属性意味着必须预先提供适当的类型。您可以尝试通过使用自定义类型转换器(或其他一些自定义转换方法(来帮助在使用反射之前在运行时转换类型来规避此问题。下面是 TypeConverter 实现的粗略示例。
public class MyIdTypeConverter : TypeConverter
{
public override object ConvertFrom(ITypeDescriptorContext context,
System.Globalization.CultureInfo culture,
object value)
{
if (value is int)
return new MyId((int)value);
else if (value is MyId)
return value;
return base.ConvertFrom(context, culture, value);
}
}
下面是我们将尝试设置 Custom
属性的类型。
public class Container
{
[TypeConverter(typeof(MyIdTypeConverter))]
public MyId Custom { get; set; }
}
调用它的代码必须检查属性并提前执行转换,之后它可以调用SetValue
。
var instance = new Container();
var type = typeof(Container);
var property = type.GetProperty("Custom");
var descriptor = TypeDescriptor.GetProperties(instance)["Custom"];
var converter = descriptor.Converter;
property.SetValue(instance, converter.ConvertFrom(15), null);