有人可以解释为什么这不会像我认为的那样有效。
double[] numbers1 = { 2.0, 2.1, 2.2, 2.3, 2.3, 2.3, 2.4, 2.5 };
double[] numbers2 = { 2.2 };
IEnumerable<double> onlyInFirstSet = numbers1.Except(numbers2);
foreach (double number in onlyInFirstSet)
Console.WriteLine(number);
/*
This code produces the following output:
2
2.1
2.3
2.4
2.5
*/
我期望的是2,2.1,2.3,2.3,2.3,2.4,2.5。为什么除了返回一个不同的列表?这是一个错误吗?
更新
好的,完全错过了文档中的那一点。有趣的4个人回答相同的答案。你会认为你会先投票给那个先回答它的人。:)
答案 0 :(得分:9)
为什么除了返回一个不同的列表?这是一个错误吗?
不。 Except
生成设置差异。请参阅documentation:
使用默认的相等比较器来比较值,生成两个序列的集合差异。
要执行您想要的操作,只需使用Where
来适当地过滤值。例如:
"abcdddefffg".Where(e => !"cde".Contains(e)); // Produces "abfffg".
答案 1 :(得分:1)
这实际上是正确的行为。记录Except
方法以返回两个IEnumerable参数的 set 差异。由于定义,集合不能包含重复元素,因此在结果中将其删除。有关详细信息,请参阅MSDN docs。
答案 2 :(得分:1)
因为“Except”是“set”函数,“set”的概念被定义为唯一的项列表。换句话说,按定义设置不能包含重复项。