作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个带有 OrderBy 和 ThenBy 的 linq 查询(与数据库无关)
var sortedList = unsortedList
.OrderBy(foo => foo.Bar) //this property access is relatively fast
.ThenBy(foo => foo.GetCurrentValue()) //this method execution is slow
获取 foo.Bar
很快,但是执行 foo.GetCurrentValue()
很慢。返回值仅在某些成员具有相等的 Bar 值时才重要,这种情况很少发生,但在发生时必须考虑。是否可以选择仅在 Bar 值相等的情况下需要平局时才执行 ThenBy 子句? (即,如果 foo.Bar 值是唯一的,则不会执行)。
另外,实际上 Bar 也有点慢,所以最好不要为同一个对象调用它两次。
最佳答案
由于您不在数据库中,并且您需要对排序进行严格控制,因此您可以将单个 OrderBy 与自定义 IComparer 结合使用,该 IComparer 仅访问它需要的内容,并且不执行不必要的评估。
关于c# - 如何指定仅在出现平局时才使用 Linq ThenBy 子句?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10695414/
我正在为我的作业制作井字游戏,老师告诉我在只能打印领带的情况下打印领带。 (假设玩家不聪明)例如, x o x- - -o x o can only result in a tie so when t
所以当我开始编写这个函数时,我正在编写一个石头剪刀布游戏: a是玩家自己的举动,b是玩家二的举动。我需要弄清楚的是,第一个玩家是赢了、输了还是平了。 //rock=0, paper=1, scisso
我知道用 PHP 可以做到这一点,但是有没有办法只用 MySQL 来做到这一点? 我有这个数据库: --------------------------------------------------
我是一名优秀的程序员,十分优秀!