在C#中,我试图通过随机索引从列表中获取项目。检索完后,我希望将其删除,以便不再选择它。好像我需要很多操作才能做到这一点,是不是我可以从列表中简单地提取项目? RemoveAt(index)函数为void。我希望有一个返回值。
我在做什么:
List<int> numLst = new List<int>();
numLst.Add(1);
numLst.Add(2);
do
{
int index = rand.Next(numLst.Count);
int extracted = numLst[index];
// do something with extracted value...
numLst.removeAt(index);
}
while(numLst.Count > 0);
我想做什么:
List<int> numLst = new List<int>();
numLst.Add(1);
numLst.Add(2);
do
{
int extracted = numLst.removeAndGetItem(rand.Next(numLst.Count));
// do something with this value...
}
while(numLst.Count > 0);
是否存在这样的“removeAndGetItem”函数?
答案 0 :(得分:16)
不,因为它违反了纯函数礼仪,其中一种方法既有副作用,又返回一个有用的值(即不只是指示一个错误状态) - 从来都不是。
如果你希望函数看起来是原子的,你可以在列表上获得一个锁定,这将阻止其他线程在你修改它时访问列表:
public static class Extensions
{
public static T RemoveAndGet<T>(this IList<T> list, int index)
{
lock(list)
{
T value = list[index];
list.RemoveAt(index);
return value;
}
}
}
答案 1 :(得分:5)
public static class ListExtensions
{
public static T RemoveAndGetItem<T>(this IList<T> list, int iIndexToRemove}
{
var item = list[iIndexToRemove];
list.RemoveAt(iIndexToRemove);
return item;
}
}
这些称为extension methods,称为new List<T>().RemoveAndGetItem(0)
。
扩展方法中需要考虑的事项
使用您传递的索引进行异常处理,在执行此操作之前检查索引是否为0以及列表的计数。