栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

浅谈C#中List对象的深度拷贝问题

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

浅谈C#中List对象的深度拷贝问题

一、List对象中的T是值类型的情况(int 类型等)

对于值类型的List直接用以下方法就可以复制:

List oldList = new List(); 
oldList.Add(..); 
List newList = new List(oldList); 

二、List对象中的T是引用类型的情况(例如自定义的实体类)

1、对于引用类型的List无法用以上方法进行复制,只会复制List中对象的引用,可以用以下扩展方法复制:

static class Extensions 
 { 
     public static IList Clone(this IList listToClone) where T: ICloneable 
     { 
  return listToClone.Select(item => (T)item.Clone()).ToList(); 
     } 
 //当然前题是List中的对象要实现ICloneable接口
 } 

2、另一种用序列化的方式对引用对象完成深拷贝,此种方法最可靠

public static T Clone(T RealObject) 

{ 
   using (Stream objectStream = new MemoryStream()) 
   { 
      //利用 System.Runtime.Serialization序列化与反序列化完成引用对象的复制
IFormatter formatter = new BinaryFormatter(); 
formatter.Serialize(objectStream, RealObject); 
objectStream.Seek(0, SeekOrigin.Begin); 
return (T)formatter.Deserialize(objectStream); 
   } 
}

3、利用System.Xml.Serialization来实现序列化与反序列化

public static T Clone(T RealObject) 
{ 
      using(Stream stream=new MemoryStream())
      {
 XmlSerializer serializer = new XmlSerializer(typeof(T));
 serializer.Serialize(stream, RealObject);
 stream.Seek(0, SeekOrigin.Begin);
 return (T)serializer.Deserialize(stream);
      }
}

三、对上述几种对象深拷贝进行测试

测试如下:

using System;
using System.Collections.Generic;
using System.Collections ;
using System.Linq;
using System.Text;
using System.IO;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Formatters.Binary;

namespace LINQ
{
  [Serializable]
  public class tt
  {
    private string name = "";

    public string Name
    {
      get { return name; }
      set { name = value; }
    }
    private string sex = "";

    public string Sex
    {
      get { return sex; }
      set { sex = value; }
    }
  }

  class LINQTest
  {
    public static T Clone(T RealObject) 
    { 
      using (Stream objectStream = new MemoryStream()) 
      { 
 IFormatter formatter = new BinaryFormatter(); 
 formatter.Serialize(objectStream, RealObject); 
 objectStream.Seek(0, SeekOrigin.Begin); 
 return (T)formatter.Deserialize(objectStream); 
      } 
    }


    public static void Main()
    {
      List lsttt = new List();
      tt tt1 = new tt();
      tt1.Name = "a1";
      tt1.Sex = "20";
      lsttt.Add(tt1);
      List l333 = new List();
      l333.Add(Clone(lsttt[0]));
      l333[0].Name = "333333333";
   }
 }
}

以上这篇浅谈C#中List对象的深度拷贝问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号