微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决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 举报,一经查实,本站将立刻删除。