问题描述
我想从这个经常运行的比较中获得速度最优化的代码:
int Object::Compare(Object *other) {
if(id < other->id) return -1;
if(id > other->id) return 1;
return 0;
}
id
变量是一个无符号的 32 位整数。
我发现,即使通过编译指示打开速度优化(通常调试版本不使用优化),我仍然看到程序集效率低下,它两次读取 id 变量并进行比较两次,即使我只需要进行一次比较。
此代码的变化无济于事。在这种特定情况下,我正在使用 Visual C++ 进行编译并查看输出,尽管代码也旨在针对 Linux 环境进行编译(尽管仍然是 x86)。我想知道的是,有没有更好的方法来构造它,以便编译器可以理解它应该只比较一次,然后使用比较标志来处理其余的?
如果我能得到任何像 cmov
这样的非分支指令,那就更好了。有什么想法吗?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)