您可以将其添加为扩展方法:
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
是在大多数情况下,很难信任。