把一个List<T>的数据复制至另一个List<T>

把一个数据集List<T>复制至到另一个数据集List<T>。

方法一,可以使用循环,然后把每一个T添加至另一个集合中去:

 

复制代码
 public void ListDemo()
        {
            var listA = new List<int> { 2, 5, 6, 8, 23, 56, 4 };
            var listB = new List<int>();

            foreach (int a in listA)
            {
                listB.Add(a);
            }
        }
Source Code
复制代码

 

方法二,使用GetRange方法:

 

复制代码
 public void ListDemo_A()
        {
            var listA = new List<int> { 2, 5, 6, 8, 23, 56, 4 };
            var listB = listA.GetRange(0, listA.Count);
        }
Source Code
复制代码

 

方法三,深度拷贝:

 

复制代码
 public void ListDemo_B()
        {
            var listA = new List<int> { 2, 5, 6, 8, 23, 56, 4 };
            var listB = new List<int>();

            using (MemoryStream ms = new MemoryStream())
            {
                BinaryFormatter bf = new BinaryFormatter();
                bf.Serialize(ms, listA);
                ms.Position = 0;
                listB = (List<int>)bf.Deserialize(ms);
            }            
        }
Source Code
复制代码

 

方法四,直接加载法:

 

复制代码
 public void ListDemo_C()
        {
            var listA = new List<int> { 2, 5, 6, 8, 23, 56, 4 };
            var listB = new List<int>(listA);            
        }
Source Code
复制代码

 

方法五:使用序列化与反序列化:

复制代码
 public void ListDemo_D()
        {
            var listA = new List<int> { 2, 5, 6, 8, 23, 56, 4 };
            var listB = JsonConvert.DeserializeObject<List<int>>(JsonConvert.SerializeObject(listA));
        }
Source Code
复制代码



不管是哪一种方法,可以抽控制台输出ListB集合:

 foreach (int inta in listB)
            {
                Console.WriteLine(inta);
            }

 

 

以下内容于2017-12-17 21:43分添加:

上面几个方法中,发现没有入口,可以

 

运行:
f

 

posted @   Insus.NET  阅读(17624)  评论(3编辑  收藏  举报
编辑推荐:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
阅读排行:
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 推荐几款开源且免费的 .NET MAUI 组件库
· 实操Deepseek接入个人知识库
· 易语言 —— 开山篇
· 【全网最全教程】使用最强DeepSeekR1+联网的火山引擎,没有生成长度限制,DeepSeek本体
历史上的今天:
2016-12-27 在你的ASP.NET MVC中使用查找功能
2014-12-27 enum to IEnumerable<T>
2010-12-27 SQL Server触发器Trigger
2010-12-27 SQL流程控制元素WHILE
2010-12-27 SQL流程控制元素IF...ELSE
2010-12-27 must be the first statement in a query batch
2010-12-27 存储过程接收Array参数传入
点击右上角即可分享
微信分享提示