BUG导致子集合List.remove同时会导致父集合List.remove
这就会出现很麻烦的情况,解决办法如下所示。
情形如下所示
TestA.cs
...
public List<int> int_list_A = new List<int>();
...
TestB.cs
...
public TestA testA;
public List<int> int_list_b = new List<int> ();
...
void Start()
{
int_list_b = testA.int_list_A;//这样赋值会导致一个BUG。
//为了避免这个BUG//int_list_b = new List<int> (testA.int_list_A);
}
...
///当UGUI按钮按下的时候调用的函数
public void ButtonPush()
{
int_list_b.Remove(int_);//由于上面 int_list_b = testA.int_list_A; 会导致这里出现BUG等同于testA.int_list_A.Remove(int_);
}
...
int_list_b = testA.int_list_A;//这样赋值会导致一个BUG。
//为了避免这个BUG//int_list_b = new List<int> (testA.int_list_A);
这样
int_list_b = new List<int> (testA.int_list_A);
才能使得TestB里面的int_list_b.remove();正常运行

本文探讨了在C#中从一个List对象直接赋值给另一个List对象时可能遇到的BUG,并提供了解决方案。通过使用深拷贝(new List<int>(source))而非浅拷贝,可以避免修改一个List时意外地影响到另一个List。
728

被折叠的 条评论
为什么被折叠?



