您可以将其添加为扩展方法:
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-net 等。
请注意,如果没有序列化,深度克隆会很棘手;特别ICloneable
是在大多数情况下很难信任。