答案:在.NET中实现深度克隆需复制对象及其引用的所有子对象,常用方法包括:1. 序列化(推荐),.NET Framework可用BinaryFormatter,.NET 5+推荐System.Text.Json;2. 实现ICloneable接口,手动控制但维护成本高;3. 使用FastDeepCloner等第三方库,简洁高效;4. 表达式树或IL生成,适用于高性能场景。选择依据为运行环境、性能需求与对象复杂度,多数情况JSON序列化已足够。
在 .NET 中实现对象的深度克隆,不能简单使用 MemberwiseClone(),因为那只是浅拷贝。深度克隆意味着新对象和原对象完全独立,包括它们内部引用的所有对象也都被复制,而不是共享引用。以下是几种常用的深度克隆方法:
二进制序列化(.NET Framework)
适用于 .NET Framework 项目(注意:.NET 5+ 不支持 BinaryFormatter):using System; using System.IO; using System.Runtime.Serialization.Formatters.Binary; public static T DeepClone(T obj) { if (obj == null) return default(T); using (var ms = new MemoryStream()) { var formatter = new BinaryFormatter(); formatter.Serialize(ms, obj); ms.Position = 0; return (T)formatter.Deserialize(ms); } }
JSON 序列化(跨平台推荐)
适用于 .NET Core / .NET 5+,更安全、跨平台:using System.Text.Json; public static T DeepCloneJson要求:对象的属性需为 public,且有 getter/setter。复杂类型需支持序列化。(T obj) { var json = JsonSerializer.Serialize(obj); return JsonSerializer.Deserialize (json); }
public class Person : ICloneable
{
public string Name { get; set; }
public Address Address { get; set; }
public object Clone()
{
var clone = new Person
{
Name = this.Name,
Address = this.Address?.Clone() as Address // 假设 Address 也实现了 Clone
};
return clone;
}
}
public class Address : ICloneable
{
public string City { get; set; }
public object Clone() => new Address { City = this.City };
}
优点是性能好、可控性强;缺点是代码量大,嵌套多时维护麻烦。
示例:使用 FastDeepCloner(NuGet 包)
Instal使用:l-Package FastDeepCloner
var clonedObj = DeepCloner.Clone(originalObj);性能优秀,语法简洁,适合复杂对象。
基本上就这些常用方式。选择哪种取决于你的运行环境(.NET Framework 还是 .NET 5+)、性能要求和对象结构复杂度。对于大多数情况,JSON 序列化已经足够安全且易用。