C#中高效创建克隆子数组
在处理数组时,经常需要从现有数组中创建包含特定元素范围的子数组。虽然可以通过手动循环和复制元素来实现,但存在更高效、更简洁的方法。
为了创建克隆子数组,可以使用扩展方法。以下是实现方法:
<code class="language-csharp">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; }</code>
使用方法如下:
<code class="language-csharp">int[] data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; int[] sub = data.SubArray(3, 4); // 包含 {3, 4, 5, 6}</code>
对于元素为复杂对象的克隆子数组,可以使用序列化进行深复制:
<code class="language-csharp">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); } }</code>
此方法要求对象可序列化。
以上是如何在 C# 中高效创建克隆子数组?的详细内容。更多信息请关注PHP中文网其他相关文章!