复制 ArrayList 的时候,使用 ArrayList.Clone() 方法复制出来的新 ArrayList 之中元素的值会随着源 ArrayList 中元素的值发生变化而一起改变。
查 MSDN:集合的浅表副本仅复制集合的元素(不论它们是引用类型还是值类型),但不复制引用所引用的对象。新集合中的引用与原始集合中的引用指向相同的对象。与之相对,集合的深层副本将复制这些元素以及由它们直接或间接引用的所有内容。
ArrayList.Clone() 返回值是 ArrayList 的浅表副本。
上网查了一下,大多数是新建一个实例,逐条复制 property,使用 for 实现:
我们知道,对于自定义的类,一般通过继承 ICloneable接口,重写 Clone() 方法来自己实现深拷贝。
因此如果类有继承 ICloneable 接口,也可以这么写:
另外让类实现 ISerializable 接口,通过序列化反序列化,我试了一下没有问题:
对于 ICollection,应该都差不多吧。
参考: http://topic.csdn.net/t/20051026/10/4350726.html
查 MSDN:集合的浅表副本仅复制集合的元素(不论它们是引用类型还是值类型),但不复制引用所引用的对象。新集合中的引用与原始集合中的引用指向相同的对象。与之相对,集合的深层副本将复制这些元素以及由它们直接或间接引用的所有内容。
ArrayList.Clone() 返回值是 ArrayList 的浅表副本。
上网查了一下,大多数是新建一个实例,逐条复制 property,使用 for 实现:
for
(
int
i
=
0
; i
<
arraylist1.Count; i
++
)
{
Class t = new Class(); // Class是类名
// 下面这句,若类 Class 中若有 很多 Property,就要写很多行
t. property = (Class)arraylist1[i]. property ;
arraylist2.Add(t);
}
{
Class t = new Class(); // Class是类名
// 下面这句,若类 Class 中若有 很多 Property,就要写很多行
t. property = (Class)arraylist1[i]. property ;
arraylist2.Add(t);
}
我们知道,对于自定义的类,一般通过继承 ICloneable接口,重写 Clone() 方法来自己实现深拷贝。
因此如果类有继承 ICloneable 接口,也可以这么写:
for
(
int
i
=
0
; i
<
list1.Count; i
++
)
{
// Clone()返回类型为Object,因此还要转换
list2.Add( (Class)( ((ICloneable)list1[i]).Clone() ) );
}
{
// Clone()返回类型为Object,因此还要转换
list2.Add( (Class)( ((ICloneable)list1[i]).Clone() ) );
}
另外让类实现 ISerializable 接口,通过序列化反序列化,我试了一下没有问题:
MemoryStream ms
=
new
MemoryStream();
BinaryFormatter bf = new BinaryFormatter();
bf.Serialize(ms,list1); // list1中元素的类要实现ISerializable接口
ms.Seek( 0 , SeekOrigin.Begin);
ArrayList list2 = (ArrayList)bf.Deserialize(ms);
BinaryFormatter bf = new BinaryFormatter();
bf.Serialize(ms,list1); // list1中元素的类要实现ISerializable接口
ms.Seek( 0 , SeekOrigin.Begin);
ArrayList list2 = (ArrayList)bf.Deserialize(ms);
对于 ICollection,应该都差不多吧。
参考: http://topic.csdn.net/t/20051026/10/4350726.html