前言:日常啪啪啪代碼的時候,常常遇到淺復制與深復制的問題,下面就自己經驗寫寫
Clone()
有時候在項目中需要得到一個對象在某個狀態下的副本,為了避免重新創建一個對象再一一賦值,便可以使用克隆來處理,克隆分為淺拷貝和深拷貝。
淺拷貝
淺拷貝自帶方法MemberwiseClone() 對於值類型和String類型成員,淺拷貝會在副本中重新創建成員;對於引用類型,對象和副本對象引用同一個內存地址,當在對象或者副本對象修改引用成員后,引用類型的成員就發生變化。
class Program { static void Main(string[] args) { Person p = new Person() { Age=12, Name="張三" }; Person p2 = (Person)p.Clone(); p2.Name = "李四"; Console.WriteLine("p.Name="+ p.Name); Console.WriteLine("p2.Name=" + p2.Name); Console.ReadKey(); } } public class Person:System.ICloneable { public string Name { get; set; } public int Age { get; set; } public object Clone() { return this.MemberwiseClone(); } }
輸出結果:

深拷貝
深拷貝不管是值類型還是引用類型,對象和副本對象修改成員屬性都只會改變各自對象的值,兩個對象是完全獨立的實體。
1. 第一種實現方式
class People { public int _age; public string _name; public People(int Age,string Name) { _age = Age; _name = Name; } public object Clone() { People MySelf = new People(this._age,this._name); return MySelf; } }
2. 第二種實現方式
class Program { static void Main(string[] args) { Person p = new Person() { Age=12, Name="張三" , Address = new Address() { Provice = "上海", City = "上海市" } }; //淺拷貝 Person p2 = (Person)p.Clone(); p2 .UserName = "淺拷貝用戶名"; p2 .Address.Provice = "淺拷貝上海"; //通過序列化、反序列化實現深拷貝 Person p3= JsonConvert.DesperializeObject<Person>(JsonConvert.SerializeObject(p)); p3.UserName = "深拷貝用戶名"; p3.Address.Provice = "深拷貝上海"; } } public class Address { public string Provice { get; set; } public string City { get; set; } } public class Person:System.ICloneable { public string Name { get; set; } public int Age { get; set; } public object Clone() { return this.MemberwiseClone(); } }
