我有一个列表,其中填充了来自操作的一些数据,并将其存储在内存缓存中。现在我想要另一个列表,它包含列表中基于某些条件的一些子数据。
从下面的代码中可以看出,我正在对目标列表进行一些操作。问题是,无论我对目标列表做了什么更改,都会对mainList进行更改。我认为这是因为引用是相同的或什么的。
我所需要的就是目标列表上的操作不会影响主列表中的数据。
List<Item> target = mainList;
SomeOperationFunction(target);
void List<Item> SomeOperationFunction(List<Item> target)
{
target.removeat(3);
return target;
}发布于 2012-12-21 02:02:15
您需要在您的方法中克隆列表,因为List<T>是一个类,所以它是引用类型的,并通过引用传递。
例如:
List<Item> SomeOperationFunction(List<Item> target)
{
List<Item> tmp = target.ToList();
tmp.RemoveAt(3);
return tmp;
}或
List<Item> SomeOperationFunction(List<Item> target)
{
List<Item> tmp = new List<Item>(target);
tmp.RemoveAt(3);
return tmp;
}或
List<Item> SomeOperationFunction(List<Item> target)
{
List<Item> tmp = new List<Item>();
tmp.AddRange(target);
tmp.RemoveAt(3);
return tmp;
}发布于 2012-12-21 02:02:36
您需要制作列表的副本,以便对副本所做的更改不会影响原始列表。最简单的方法是在System.Linq中使用ToList扩展方法。
var newList = SomeOperationFunction(target.ToList());发布于 2012-12-21 02:02:19
首先构建一个新的list并对其进行操作,因为List是一个引用类型,即当您在函数中传递它时,您不仅传递了值,还传递了实际的对象本身。
如果只是将target赋值给mainList,则两个变量都指向同一个对象,因此您需要创建一个新列表:
List<Item> target = new List<Item>(mainList);void List<Item> SomeOperationFunction()没有任何意义,因为要么什么都不返回(void),要么返回List<T>。因此,要么从您的方法中删除返回语句,要么返回一个新的List<Item>。在后一种情况下,我会将其重写为:
List<Item> target = SomeOperationFunction(mainList);
List<Item> SomeOperationFunction(List<Item> target)
{
var newList = new List<Item>(target);
newList.RemoveAt(3);
return newList;
}https://stackoverflow.com/questions/13977841
复制相似问题