有人能解释一下为什么它不能像我想的那样工作吗?
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。为什么except会返回一个不同的列表?这是一个bug吗?
更新:
好吧,在文档中完全忽略了这一点。有趣的是,4个人回答了同样的问题。你会认为你会投票给第一个回答问题的人。:)
发布于 2009-03-21 18:27:51
为什么except会返回distinct列表?这是一个bug吗?
不是的。Except会生成一个设置差异。请参阅documentation
通过使用默认的相等比较器比较值来生成两个序列的集合差值。
要执行您想要的操作,只需使用Where适当地筛选这些值。例如:
"abcdddefffg".Where(e => !"cde".Contains(e)); // Produces "abfffg".发布于 2009-03-21 18:29:43
这实际上是正确的行为。文档中记录了用于返回两个IEnumerable参数的设置差异的Except方法。由于根据定义,集合不能包含重复的元素,因此这些元素将在结果中消除。有关更多信息,请参阅MSDN docs。
发布于 2009-03-21 18:31:11
因为"Except“是一个"set”函数,而"set“的概念被定义为一个唯一的项目列表。换句话说,根据定义,集合不能包含重复项。
https://stackoverflow.com/questions/669709
复制相似问题