实现方式
通过挨个罗列的方式一次复制子对象是非常耗费人力的,如果子对象是引用类型,则还要需要考虑是否对子对象进一步深拷贝。
实际应用中,一个类如果有几十个子对象,挨个复制对于开发人员来说索然无味比较费时费力。
所以使用反射机制来实现。
但是如果是服务端运行的话,还是建议手动的实现。
毕竟反射机制比直接写出来的效率要慢一些。
代码:
| 代码如下 | 复制代码 |
publicstaticclassDeepCopyHelper {
publicstaticobjectCopy(thisobjectobj) { Object targetDeepCopyObj; Type targetType = obj.GetType(); //值类型 if(targetType.IsValueType ==true) { targetDeepCopyObj = obj; } //引用类型 else { targetDeepCopyObj = System.Activator.CreateInstance(targetType); //创建引用对象 System.Reflection.MemberInfo[] memberCollection = obj.GetType().GetMembers();
foreach(System.Reflection.MemberInfo memberinmemberCollection) { if(member.MemberType == System.Reflection.MemberTypes.Field) { System.Reflection.FieldInfo field = (System.Reflection.FieldInfo)member; Object fieldValue = field.GetValue(obj); if(fieldValueisICloneable) { field.SetValue(targetDeepCopyObj, (fieldValueasICloneable).Clone()); } else { field.SetValue(targetDeepCopyObj, Copy(fieldValue)); }
} elseif(member.MemberType == System.Reflection.MemberTypes.Property) { System.Reflection.PropertyInfo myProperty = (System.Reflection.PropertyInfo)member; MethodInfo info = myProperty.GetSetMethod(false); if(info !=null) { objectpropertyValue = myProperty.GetValue(obj,null); if(propertyValueisICloneable) { myProperty.SetValue(targetDeepCopyObj, (propertyValueasICloneable).Clone(),null); } else { myProperty.SetValue(targetDeepCopyObj, Copy(propertyValue),null); } }
} } } returntargetDeepCopyObj; } } | |
原神祈愿模拟器最新版
原神祈愿模拟器手机版是一款完整汉化的趣味原神抽卡模拟小游戏,
宝宝森林美食完整版
宝宝森林美食游戏最新版是一款十分有趣的休闲益智游戏,帮助宝宝
g沙盒仇恨官方英文版(gorebox)
G沙盒仇恨英文原版是一款最近非常火热的沙盒模拟类游戏,在这里
迷你世界测试服最新版2024
迷你世界测试服2021最新版,即迷你世界的先遣服版本,用户能
闪耀暖暖最新版2024
闪耀暖暖手游这是非常好玩的换装手游,游戏内容丰富有趣,游戏环