浅谈对象的深度拷贝 - IClonable接口

简介: 经常我们会发现,当我们把一个对象列表赋值给另一个对象列表之后,一个改变了,另一个也跟着改变了,但是这往往不是我们想看到的那么,怎么办呢?办法只有一个,那就是让你的对象实现IClonable接口对象代码:public class Employee : ICloneable    ...

经常我们会发现,当我们把一个对象列表赋值给另一个对象列表之后,一个改变了,另一个

也跟着改变了,但是这往往不是我们想看到的

那么,怎么办呢?

办法只有一个,那就是让你的对象实现IClonable接口

对象代码:

public  class Employee : ICloneable
    {
         public  int EmployeeID {  getset; }
         public  string LastName {  getset; }
         public  string FirstName {  getset; }
         public  string Title {  getset; }
         public  string City {  getset; }
         public  string Region {  getset; }
         public  string Country {  getset; }
         public  string Notes {  getset; }

         public  override  string ToString()
        {
             string format =  " Employee ID: {0}\nFirst Name: {1}\n "
                          +  " Last Name: {2}\nTitle: {3}\nCity: {4}\n "
                          +  " Region: {5}\nCountry: {6}\nNotes: {7}\n ";

             return  string.Format(format, EmployeeID, FirstName, LastName, Title, City, Region, Country, Notes);
        }

        
         public Object Clone()
        {  
            Employee cloned =  new Employee();

            cloned.EmployeeID =  this.EmployeeID;
            cloned.LastName =  this.LastName;
            cloned.FirstName =  this.FirstName;
            cloned.Title =  this.Title;
            cloned.City =  this.City;
            cloned.Region =  this.Region;
            cloned.Country =  this.Country;
            cloned.Notes =  this.Notes;

             return cloned;  
        }
    }

 

测试代码如下:

public  void Run()
        {
            EmployeesClient employeeClient =  new EmployeesClient();
            List<Employee> srcEmployeeList = employeeClient.GetAllEmployees();

            Console.WriteLine( " Source Employee List: ");
            Console.WriteLine( " -------------------------------------------------------------------- ");
            Display(srcEmployeeList);
            Console.WriteLine( " -------------------------------------------------------------------- ");

            Console.WriteLine();
            Console.WriteLine();

            List<Employee> dstEmployeeList =  new List<Employee>();
             srcEmployeeList.ForEach(emp => dstEmployeeList.Add( (Employee)emp.Clone() ));
            
            srcEmployeeList[ 0].LastName =  " Huang ";
            srcEmployeeList[ 0].FirstName =  " Lynn ";

            Console.WriteLine( " Source Employee List After Change: ");
            Console.WriteLine( " -------------------------------------------------------------------- ");
            Display(srcEmployeeList);
            Console.WriteLine( " -------------------------------------------------------------------- ");

            Console.WriteLine();
            Console.WriteLine();

            Console.WriteLine( " Dest Employee List: ");
            Console.WriteLine( " -------------------------------------------------------------------- ");
            Display(dstEmployeeList);
            Console.WriteLine( " -------------------------------------------------------------------- ");
        }

         private  void Display(IList<Employee> employeeList)
        {
             foreach (Employee employee  in employeeList)
            {
                Console.WriteLine(employee);
            }
        }

 

运行结果:

 

Source Employee List After Change:
--------------------------------------------------------------------
Employee ID: 1
First Name: Lynn
Last Name: Huang

......

 

 

Dest Employee List:
--------------------------------------------------------------------
Employee ID: 1
First Name: Nancy
Last Name: Davolio

......

 

 

目录
相关文章
|
数据采集 数据挖掘 定位技术
python基于淘宝历史数据的用户行为分析(一)
python基于淘宝历史数据的用户行为分析(一)
python基于淘宝历史数据的用户行为分析(一)
|
SQL 存储 数据库
OceanBase数据库优化
【8月更文挑战第14天】OceanBase数据库优化
648 2
|
前端开发 JavaScript
#yyds干货盘点# 【js学习笔记二十六】前端原型和原型链构造函数
#yyds干货盘点# 【js学习笔记二十六】前端原型和原型链构造函数
184 0
#yyds干货盘点# 【js学习笔记二十六】前端原型和原型链构造函数
|
分布式计算 资源调度 大数据
[Hadoop]Hadoop YARN的发展史与详细解析
带有 MapReduce 的 Apache Hadoop 是分布式数据处理的骨干力量。借助其独特的横向扩展物理集群架构和由 Google 最初开发的精细处理框架,Hadoop 在大数据处理的全新领域迎来了爆炸式增长。
1439 0
|
存储 分布式计算 Hadoop
Hadoop大象之旅008-启动与关闭Hadoop
Hadoop大象之旅008-启动与关闭Hadoop                                                         老帅    Hadoop是一个运行在Linux文件系统上的分布式文件系统,在使用之前需要启动。
1443 0
|
4天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
293 116
|
19天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~