Ответ 1
Возможно, если класс, содержащий свойство, является общим, и вы объявляете свойство с помощью общего параметра:
class Foo<TValue> {
public string Value { get; set; }
public TValue TypedValue {
get {
return (TValue)Convert.ChangeType(Value, tyepof(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);
}
}