您可以将其添加为扩展方法:
public static T[] SubArray<T>(this T[] data, int index, int length){ T[] result = new T[length]; Array.Copy(data, index, result, 0, length); return result;}static void Main(){ int[] data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; int[] sub = data.SubArray(3, 4); // contains {3,4,5,6}}
更新重新克隆(在原始问题中并不明显)。如果您 真的 想要深入的克隆,就像是:
public static T[] SubArrayDeepClone<T>(this T[] data, int index, int length){ T[] arrCopy = new T[length]; Array.Copy(data, index, arrCopy, 0, length); using (MemoryStream ms = new MemoryStream()) { var bf = new BinaryFormatter(); bf.Serialize(ms, arrCopy); ms.Position = 0; return (T[])bf.Deserialize(ms); }}
不过,这确实要求对象可序列化(
[Serializable]或
ISerializable)。你可以很容易地替代任何其他串行酌情-
XmlSerializer,
DataContractSerializer,protobuf网等。
请注意,如果不进行序列化,则深度克隆很棘手。特别
ICloneable是在大多数情况下,很难信任。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)