透過列表的深層副本實現真正的物件獨立性
範例程式碼顯示了兩個包含 List<Book> books_1
物件的清單(List<Book> books_2
和 Book
)。 簡單的賦值使 books_2
看起來是 books_1
的副本,但對 books_2
的更改也會影響 books_1
,因為它們共享相同 Book
物件的引用。
深度克隆的重要性
要建立真正獨立的副本,我們必須避免共享引用。 這需要創建全新的Book
物件並用原始資料填充它們——這個過程稱為深度複製。
實作深度複製
可以使用帶有 Select
或 ConvertAll
方法的 lambda 表達式高效地建立深拷貝:
使用Select
:
<code class="language-csharp">List<Book> books_2 = books_1.Select(book => new Book(book.title)).ToList();</code>
使用ConvertAll
:
<code class="language-csharp">List<Book> books_2 = books_1.ConvertAll(book => new Book(book.title));</code>
兩種方法都會在 lambda 表達式中產生新的 Book
實例,從原始 title
物件複製 Book
屬性。 產生的 books_2
清單包含全新的、獨立的 Book
物件。
深度複製的優點
深度複製可確保對 books_2
的修改不會影響 books_1
。當您需要使用修改後的副本而不更改原始資料時,這一點至關重要。 這種方法保證了資料完整性並防止意外的副作用。
以上是如何建立清單的深層副本以實現真正的物件獨立性?的詳細內容。更多資訊請關注PHP中文網其他相關文章!