反汇编之 条件表达式

#include <stdio.h>

int main()
{
    int result = -1;

    result = (2 - 1 ? 3 ? 4 : 5 : 6 ? 7 : 8);
    printf("result = %d\n", result);        // 4

    result = (1 == 2 - 1 ? 3 ? 4 : 5 : 6 ? 7 : 8);
    printf("result = %d\n", result);        // 4

    result = (2 - 2 ? 3 ? 4 : 5 : 6 ? 7 : 8);
    printf("result = %d\n", result);        // 7

    return 0;
}

/*
0000000000001149 <main>:
    1149:    f3 0f 1e fa              endbr64
    114d:    55                       push   %rbp
    114e:    48 89 e5                 mov    %rsp,%rbp
    1151:    48 83 ec 10              sub    $0x10,%rsp
    1155:    c7 45 fc ff ff ff ff     movl   $0xffffffff,-0x4(%rbp)
    115c:    c7 45 fc 04 00 00 00     movl   $0x4,-0x4(%rbp)
    1163:    8b 45 fc                 mov    -0x4(%rbp),%eax
    1166:    89 c6                    mov    %eax,%esi
    1168:    48 8d 3d 95 0e 00 00     lea    0xe95(%rip),%rdi        # 2004 <_IO_stdin_used+0x4>
    116f:    b8 00 00 00 00           mov    $0x0,%eax
    1174:    e8 d7 fe ff ff           callq  1050 <printf@plt>
    1179:    c7 45 fc 04 00 00 00     movl   $0x4,-0x4(%rbp)
    1180:    8b 45 fc                 mov    -0x4(%rbp),%eax
    1183:    89 c6                    mov    %eax,%esi
    1185:    48 8d 3d 78 0e 00 00     lea    0xe78(%rip),%rdi        # 2004 <_IO_stdin_used+0x4>
    118c:    b8 00 00 00 00           mov    $0x0,%eax
    1191:    e8 ba fe ff ff           callq  1050 <printf@plt>
    1196:    c7 45 fc 07 00 00 00     movl   $0x7,-0x4(%rbp)
    119d:    8b 45 fc                 mov    -0x4(%rbp),%eax
    11a0:    89 c6                    mov    %eax,%esi
    11a2:    48 8d 3d 5b 0e 00 00     lea    0xe5b(%rip),%rdi        # 2004 <_IO_stdin_used+0x4>
    11a9:    b8 00 00 00 00           mov    $0x0,%eax
    11ae:    e8 9d fe ff ff           callq  1050 <printf@plt>
    11b3:    b8 00 00 00 00           mov    $0x0,%eax
    11b8:    c9                       leaveq
    11b9:    c3                       retq   
    11ba:    66 0f 1f 44 00 00        nopw   0x0(%rax,%rax,1)
*/

反汇编代码简单明了,直接给出结果,中间的运算流程没了。

分析一下计算流程:

以 (1 == 2 - 1 ? 3 ? 4 : 5 : 6 ? 7 : 8) 为例。

首先需要搞清楚运算符优先级和结合方式。以上表达式中减号(-)的优先级最高,其次是双等号(==),且条件运行符是由右向左。运算流程如下。

(1 == 2 - 1 ? 3 ? 4 : 5 : 6 ? 7 : 8)

= (1 == 1 ? 3 ? 4 : 5 : 6 ? 7 : 8)   # 先减

= (1 ? 3 ? 4 : 5 : 6 ? 7 : 8)           # 再双等,1==1,取1

= (1 ? 3 ? 4 : 5 : 7)                      # 6 ? 7 : 8  ==> 7

= (1 ? 4 : 7)                                 # 3 ? 4 : 5   ==> 4

= 4

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值