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中文網其他相關文章!