写法1: scores.GroupBy(x=>x.StuID).OrderBy(x =>x.Sum()).ThenBy(x => x.Key)
写法2: scores.GroupBy(x=>x.StuID).OrderBy(x =>x.Key).OrderBy(x=>x.Sum())
link以下两种写法结果一样,有什么区别?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- threenewbee 2014-12-29 14:32关注
写法2不推荐,理论上这个结果和写法1一样,但是基于这样一个假设,那就是OrderBy执行的是稳定的排序。
所谓稳定的排序,就是如果原始序列中两个元素根据排序条件相等,那么排序后它们保持排序前的相对顺序。
因为Linq to Object的排序是稳定的,所以结果一样,但是如果Linq To 其它提供程序不能做到这一点,可能排序结果不可预料,而且从语义上说,也不如前者好。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报