unsigned int 的高效比较C++ 编译器优化

问题描述

我想从这个经常运行的比较中获得速度最优化的代码

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 (将#修改为@)