为什么模 2 优化与 x&1 不同?

问题描述

为什么是这段代码的汇编输出

代码

int 
f(int n) {
        return n % 2;
}

汇编

f:
        mov     edx,edi
        shr     edx,31
        lea     eax,[rdi+rdx]
        and     eax,1
        sub     eax,edx
        ret

与此不同:

代码

int 
g(int n) {
        return n & 1;
}

汇编

g:
        mov     eax,edi
        and     eax,1
        ret

我在网上找不到任何东西(也许我没有使用正确的关键字)。

注意:

  • 编译器:gcc
  • 参数:-O3

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)