Это возможно, если класс, содержащий свойство, является универсальным, и вы объявляете свойство с помощью универсального параметра:
class Foo<TValue> {
public string Value { get; set; }
public TValue TypedValue {
get {
return (TValue)Convert.ChangeType(Value, typeof(TValue));
}
}
}
Вместо этого можно использовать универсальный метод:
class Foo {
public string Value { get; set; }
public Type TheType { get; set; }
public T CastValue<T>() {
return (T)Convert.ChangeType(Value, typeof(T));
}
}
Вы также можете использовать классы System.ComponentModel.TypeConverter
для преобразования, поскольку они позволяют классу определять собственный конвертер.
Редактировать : обратите внимание, что при вызове универсального метода необходимо указать параметр универсального типа, так как компилятор не может его вывести:
Foo foo = new Foo();
foo.Value = "100";
foo.Type = typeof(int);
int c = foo.CastValue<int>();
Вы должны знать тип во время компиляции. Если вы не знаете тип во время компиляции, вы должны хранить его в object
, и в этом случае вы можете добавить следующее свойство в класс Foo
:
public object ConvertedValue {
get {
return Convert.ChangeType(Value, Type);
}
}