代码

using System;
using System.Collections.Generic;
using System.Text;
using System.Collections;
using System.Reflection;

namespace Common.CloneObjBase
{
    /// <summary>   
    /// BaseObject类是一个用来继承的抽象类。    
    /// 每一个由此类继承而来的类将自动支持克隆方法。   
    /// 该类实现了Icloneable接口,并且每个从该对象继承而来的对象都将同样地   
    /// 支持Icloneable接口。    
    /// </summary>    
    public abstract class CloneObj : ICloneable
    {
        /// <summary>
        /// Author:Evan Lee
        /// QQ:278631309
        /// Blog:http://www.cnblogs.com/magic_evan
        /// Email:Can't be Find
        /// </summary>
        /// <typeparam name="T">要返回的克隆对象;该对象须为class</typeparam>
        /// <param name="Tobj">要进行克隆的对象实例</param>
        /// <returns></returns>
        public T Clone<T>(T Tobj) where T : class
        {

//首先我们建立指定类型的一个实例            
            object newObject = Activator.CreateInstance(typeof(T));
            //我们取得新的类型实例的字段数组。            
            FieldInfo[] fields = newObject.GetType().GetFields();
            int i = 0;
            foreach (FieldInfo fi in typeof(T).GetFields())
            {
                //我们判断字段是否支持ICloneable接口。                
                Type ICloneType = fi.FieldType.GetInterface("ICloneable", true);
                if (ICloneType != null)
                {
                    //取得对象的Icloneable接口。                    
                    ICloneable IClone = (ICloneable)fi.GetValue(Tobj);
                    //我们使用克隆方法给字段设定新值。                   
                    fields[i].SetValue(newObject, IClone.Clone());
                }
                else
                {
                    // 如果该字段部支持Icloneable接口,直接设置即可。                    
                    fields[i].SetValue(newObject, fi.GetValue(Tobj));
                }
                //现在我们检查该对象是否支持IEnumerable接口,如果支持,                
                //我们还需要枚举其所有项并检查他们是否支持IList 或 IDictionary 接口。               
                Type IEnumerableType = fi.FieldType.GetInterface("IEnumerable", true);
                if (IEnumerableType != null)
                {
                    //取得该字段的IEnumerable接口                   
                    IEnumerable IEnum = (IEnumerable)fi.GetValue(Tobj);
                    Type IListType = fields[i].FieldType.GetInterface("IList", true);
                    Type IDicType = fields[i].FieldType.GetInterface("IDictionary", true);
                    int j = 0;
                    if (IListType != null)
                    {
                        //取得IList接口。                        
                        IList list = (IList)fields[i].GetValue(newObject);
                        foreach (object obj in IEnum)
                        {
                            //查看当前项是否支持支持ICloneable 接口。                            
                            ICloneType = obj.GetType().GetInterface("ICloneable", true);
                            if (ICloneType != null)
                            {
                                //如果支持ICloneable 接口,             
                                //我们用它李设置列表中的对象的克隆            
                                ICloneable clone = (ICloneable)obj;
                                list[j] = clone.Clone();
                            }
                            //注意:如果列表中的项不支持ICloneable接口,那么                         
                            //在克隆列表的项将与原列表对应项相同                         
                            //(只要该类型是引用类型)                           
                            j++;
                        }
                    }
                    else if (IDicType != null)
                    {
                        //取得IDictionary 接口                       
                        IDictionary dic = (IDictionary)fields[i].GetValue(newObject);
                        j = 0;
                        foreach (DictionaryEntry de in IEnum)
                        {
                            //查看当前项是否支持支持ICloneable 接口。                            
                            ICloneType = de.Value.GetType().
                                GetInterface("ICloneable", true);
                            if (ICloneType != null)
                            {
                                ICloneable clone = (ICloneable)de.Value;
                                dic[de.Key] = clone.Clone();
                            }
                            j++;
                        }
                    }
                }
                i++;
            }
            return newObject as T;
        }

#region ICloneable 成员

public object Clone()
        {
            return base.MemberwiseClone();
            //throw new Exception("The method or operation is not implemented.");
        }

#endregion
    }
}

转载于:https://www.cnblogs.com/magic_evan/archive/2010/04/22/1718226.html

返回对应对象的克隆方法相关推荐

  1. (创建型)2、原型模式(返回原对象的克隆体,不直接返回原对象)

    原型模式在JDK 中对应的就是 Cloneable接口. 如果一个对象想要调用clone方法(Object中有定义)得到一个对象的克隆体,需要实现Cloneable接口. 否则会报java.lang. ...

  2. 根据接口入参不同返回不同对象集合的方法

    最近要写一个外部调用的webservice接口,入参和出参都是xml格式,根据不同的type查询不同的集合返回,代码如下: 首先配置webservice接口的xml文件 然后写接口类 然后是实现类 实 ...

  3. 对象的克隆——原型模式

    本文转载自 :http://blog.csdn.net/lovelion/article/details/7424559 张纪中版<西游记>以出乎意料的造型和雷人的台词遭到广大观众朋友的热 ...

  4. 【设计模式】对象的克隆-原型模式

    原型模式是对象的创建模式.原型模式使用原型实例指定创建对象的类型,通过克隆原型来创建新的对象,其实就是复制对象. 原型模式在我们的生活中处处都存在,大家应该用过很多软件,都有模板,就拿我现在用的思维导 ...

  5. Java对象克隆方法(浅克隆、深克隆)

    要让一个对象进行克隆,其实就是两个步骤: 1. 让该类实现java.lang.Cloneable接口: 2. 重写(override)Object类的clone()方法. 上面的克隆方法其实是浅克隆, ...

  6. Java基础学习总结(127)——Java方法应该返回空对象还是null

    Java方法应该返回空对象还是null? 大多数情况下就是在需要返回值的方法中,使用空对象(empty object)来代替返回null.理由很简单,空对象与其他有意义的对象一样,使得调用方法的用户不 ...

  7. (1)定义圆Circle类,包含radius半径属性,求面积方法,求周长方法,返返回圆对象的详细信息的方法(2)在测试类中创建长度为5的Circle[]数组,用来装5个圆对象

    import java.util.Random;class Circle{double radius;double area;double perimeter;// 面积public void ger ...

  8. jQuery方法返回jQuery对象还是DOM对象

    jQuery方法返回jQuery对象还是DOM对象 1.$()获取的对象都是jQuery对象 $("选择器") $("<tr></tr>" ...

  9. cloning java_深入浅出Java中的clone克隆方法,写得太棒了!

    作者:张纪刚 blog.csdn.net/zhangjg_blog/article/details/18369201/ 2019-03-24 10:33:04 Java中对象的创建 clone 顾名思 ...

最新文章

  1. 理解GloVe模型(Global vectors for word representation)
  2. c语言inline详解
  3. 手指贴个“创可贴”,你睡觉都能发电
  4. Python Data Science的多版本多环境管理工具Anaconda
  5. 【渝粤题库】国家开放大学2021春3896人文英语1题目
  6. java小游戏毕业论文,你不懂还不学?
  7. 谷歌、CMU发文:别压榨单模型了!集成+级联上分效率更高!
  8. flink 三种时间机制_Flink的时间类型和watermark机制
  9. for和foreach
  10. 17.TCP/IP 详解卷1 --- TCP: 传输控制协议
  11. Hololens Vuforia 物体识别
  12. linux上使用netstat查看当前服务和监听端口
  13. mysql - InnoDB存储引擎 死锁问题( Deadlock found when trying to get lock; try restarting transaction )...
  14. 大教堂与集市 The Cathedral The Bazaar -- 这是当代软件技术领域最重要的著作
  15. textbox多行文本框_文本框脚本
  16. Python 散点图的数据分析
  17. 提升网站运营效果的方法有哪些?网站运营有什么方法和技巧?
  18. Python查找算法之狄克斯特拉算法
  19. javascript实现QR code二维码扫描
  20. 云计算大数据时代IT管理的机遇和挑战

热门文章

  1. CF--思维练习--CodeForces - 221C-H - Little Elephant and Problem (思维)
  2. 玩转mini2440开发板之【编译烧录rootfs根文件系统全过程记录】
  3. 如何使用makefile编译不同平台的目标文件(makefile的参数传递)
  4. Advanced Bash-Scripting Guide 学习笔记一
  5. 树莓派gparted启动失败解决方法
  6. MySQL explain结果详解
  7. 如何成为数据科学家_成为数据科学家的5大理由
  8. 梯度提升树python_梯度增强树回归— Spark和Python
  9. python初学者编程指南_动态编程初学者指南
  10. linux C bool变量