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