下面小編就為大家帶來一篇C# 使用反射來實現對象的深度複製方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
實現方式
通過挨個羅列的方式一次複製子物件是非常耗費人力的,如果子物件是參考型別,則還要需要考慮是否對子物件進一步深拷貝。
實際應用中,一個類如果有幾十個子物件,挨個複製對於開發人員來說索然無味比較費時費力。
所以使用反射機制來實現。
但是如果是服務端啟動並執行話,還是建議手動的實現。
畢竟反射機制比直接寫出來的效率要慢一些。
代碼:
public static class DeepCopyHelper { public static object Copy(this object obj) { 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 member in memberCollection) { if (member.MemberType == System.Reflection.MemberTypes.Field) { System.Reflection.FieldInfo field = (System.Reflection.FieldInfo)member; Object fieldValue = field.GetValue(obj); if (fieldValue is ICloneable) { field.SetValue(targetDeepCopyObj, (fieldValue as ICloneable).Clone()); } else { field.SetValue(targetDeepCopyObj, Copy(fieldValue)); } } else if (member.MemberType == System.Reflection.MemberTypes.Property) { System.Reflection.PropertyInfo myProperty = (System.Reflection.PropertyInfo)member; MethodInfo info = myProperty.GetSetMethod(false); if (info != null) { object propertyValue = myProperty.GetValue(obj, null); if (propertyValue is ICloneable) { myProperty.SetValue(targetDeepCopyObj, (propertyValue as ICloneable).Clone(), null); } else { myProperty.SetValue(targetDeepCopyObj, Copy(propertyValue), null); } } } } } return targetDeepCopyObj; } }