C#中实现对象的深拷贝
深度拷贝指的是将一个引用类型(包含该类型里的引用类型)拷贝一份(在内存中完完全全是两个对象,没有任何引用关系).......... 直接上代码:
1 /// <summary> 2 /// 对象的深度拷贝(序列化的方式) 3 /// </summary> 4 public static class MyDeepCopy 5 { 6 7 /// <summary> 8 /// xml序列化的方式实现深拷贝 9 /// </summary> 10 /// <typeparam name="T"></typeparam> 11 /// <param name="t"></param> 12 /// <returns></returns> 13 public static T XmlDeepCopy<T>(T t) 14 { 15 //创建Xml序列化对象 16 XmlSerializer xml = new XmlSerializer(typeof(T)); 17 using (MemoryStream ms = new MemoryStream())//创建内存流 18 { 19 //将对象序列化到内存中 20 xml.Serialize(ms, t); 21 ms.Position = default;//将内存流的位置设为0 22 return (T)xml.Deserialize(ms);//继续反序列化 23 } 24 } 25 26 /// <summary> 27 /// 二进制序列化的方式进行深拷贝 28 /// 确保需要拷贝的类里的所有成员已经标记为 [Serializable] 如果没有加该特性特报错 29 /// </summary> 30 /// <typeparam name="T"></typeparam> 31 /// <param name="t"></param> 32 /// <returns></returns> 33 public static T BinaryDeepCopy<T>(T t) 34 { 35 //创建二进制序列化对象 36 BinaryFormatter bf = new BinaryFormatter(); 37 using (MemoryStream ms = new MemoryStream())//创建内存流 38 { 39 //将对象序列化到内存中 40 bf.Serialize(ms, t); 41 ms.Position = default;//将内存流的位置设为0 42 return (T)bf.Deserialize(ms);//继续反序列化 43 } 44 } 45 }
浅拷贝指的是将该类型里面的值类型拷贝,而该类型里的引用类型不进行拷贝,实现浅拷贝很简单,再该类里编写一个方法,方法内部调用自身的MemberwiseClone()方法即可得到一个object类型的对象,将它强转成当前对象返回即可,列如:
1 public class Person 2 { 3 public int ID { get; set; } 4 public string Name { get; set; } 5 public string Email { get; set; } 6 public Cat Cat { get; set; } 7 8 /// <summary> 9 /// Person类的浅拷贝 10 /// </summary> 11 /// <returns></returns> 12 public Person QainClone() 13 { 14 //调用自带的浅拷贝方法得到的是一个objec类型的对象,然后强转直接返回就可以了 15 return MemberwiseClone() as Person; 16 } 17 }
string是个列外

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
使用 github pages, 快速部署你的静态网页
使用 github pages, 快速部署你的静态网页 Github Pages 官网 Github Pages:Websites for you and your projects.Hosted directly from your GitHub repository. Just edit, push, and your changes are live. 前言 在日常工作中, 我们经常会遇到要做 demo 展示的情况. 做 demo 展示不同于做项目开发, 我们需要的是快速轻便的开发和部署, 而不是完备的一整套开发流程. 下图肯定不是我们做一个 demo 想要的流程. 尤其对于数据可视化工作, 能快速的创建一个 demo 来验证自己的想法, 并且方便的和同伴分享自己作品是非常重要的.在这里给大家介绍一种笔者经常用来做 demo 的方法: Github Pages. 选择 github pages 的理由 使用零成本: github pages 集成在 github 中, 直接和代码管理绑定在一起, 随着代码更新自动重新部署, 使用非常方便. 免费: 免费提供 username.gi...
- 下一篇
MSSQL sql server order by 1,2 的具体含义
原文: MSSQL sql server order by 1,2 的具体含义 转自:http://www.maomao365.com/?p=5416 摘要: order by 1,2 的含义是对表的第一列 按照从小到大的顺序进行排列 然后再对第二列按照从小到大的顺序进行排列 order by 1,2 等同于 order by [第一列],[第二列] 详见以下举例说明 create table A (keyId varchar(20),name varchar(120)) go insert into A (name,keyId)values(10,'we') insert into A (name,keyId)values(2,'b') insert into A (name,keyId)values(3,'C') insert into A (name,keyId)values(4,'a') insert into A (name,keyId)values(5,'E') insert into A (name,keyId)values(7,'F') go select * ...
相关文章
文章评论
共有0条评论来说两句吧...