所以我想知道从继承的类(B)是否可以完全重新创建我的对象的实际实例来访问那些只读属性。
例如,为了更好的解释,对于继承元组的类,如果可能,我会做这样的事情:
public new T3 Item3
{
get { return item3; }
set
{
item3 = value;
base = new Tuple<T1, T2, T3>(Item1, Item2, Item3); // Not valid
}
}
我看不出怎么做?
答案 0 :(得分:7)
元组是不可变的,因此您无法更改其值。当您拥有不可变对象时,更改它们的方法是返回一个更改了所需属性的新对象。因此,如果你想坚持使用元组,你可以这样做:
public static class TupleExtensions {
public static Tuple<T1, T2, T3>
WhereItem3Is<T1, T2, T3>(this Tuple<T1, T2, T3> self, T3 newValue) {
return Tuple.Create(self.Item1, self.Item2, newValue);
}
// other methods for Tuple<,,> or other Tuples...
}
并像这样使用它:
var t = Tuple.Create(1, 2, 3);
// ...
t = t.WhereItem3Is(4);
但是编写所有这些方法有点痛苦。因此,如果您需要其中许多,最好这样做:
var t = Tuple.Create(1, 2, 3);
t = Tuple.Create(t1.Item1, t1.Item2, 4);
您甚至可以使用一个包装器类型来引用代码中不同位置的元组,以便可以看到任何“更改”:
var t = Tuple.Create(1, 2, 3);
var r = new Ref<Tuple<int, int, int>>(t);
// share r ...
r.Value = Tuple.Create(r.Value.Item1, r.Value.Item2, 4);
...
public class Ref<T> {
public T Value { get; set; }
public Ref(T value) { Value = value; }
}
然而,所有这些感觉非常尴尬。也许您可以更好地解释您所拥有的基本问题,以便提供更好的答案。也许你真的不需要一个元组,只是对你的领域更具体的东西。