fbczr 发表于 2019-10-22 14:15:04

i++与++i的计算问题

#include <stdio.h>

int main(void)
{   
        int i = 10;   
        i = i-- - --i * ( i = -3 ) * i++ + ++i;
        printf( "i = %d\n", i );
        return 0;
}
为什么这个算出来的结果是36,有无详细计算过程。我的计算过程是这样的:10-8*(-3)*8+10但是结果不对啊

yuweb 发表于 2019-10-22 16:18:11

本帖最后由 yuweb 于 2019-10-22 17:04 编辑

36?我这边运行结果是22,可以提供下你的运行截图吗?
计算结果和第一行赋值10貌似没啥关系,我试了换个值都是一样的结果22
我的计算是(-3)-(-3)*(-3)*(-3)+(-2)=22

荒于嬉 发表于 2019-10-22 16:24:55

楼主 经过反复试验和查阅资料,我发现过程是这样的:10-(-3)*(-3)*(-3)+(-1)=36
1.从左往右运行,第一个减号左右优先级相同,所以从左向右依次执行,i=10- --i * (i=-3)* i++ + ++i (i此时为9)
2.然后()优先级大于++、--,同时,i++的优先级是要大于++i的(小甲鱼扩展阅读优先级列表内有,百度出来的第一个好像是错的)。所以后面三个数相乘部分先把(i=9)变为(i=-3),然后进行i--,然后++i,分别得(-3)*(-3)*(-3)
3.最后的+ ++i是跟随的+号前面的数而不是前面那坨数,所以最后一个数为(-1)
可能符号两边优先级不同时,就只比较符号两边的数,一个一个的比,优先级相同,就一坨一坨的比。
我是这么去理解的,如果有大神知道更加有说服力的原因,还望多多指导{:10_266:}

荒于嬉 发表于 2019-10-22 20:29:16

yuweb 发表于 2019-10-22 16:18
36?我这边运行结果是22,可以提供下你的运行截图吗?
计算结果和第一行赋值10貌似没啥关系,我试了换个值 ...

我用的dev 出来的结果是36 大概是编译环境不一样吧

人造人 发表于 2019-10-22 21:46:10

想看计算过程?
喏,看吧
        .file        "main.c"
        .text
        .def        __main;        .scl        2;        .type        32;        .endef
        .section .rdata,"dr"
.LC0:
        .ascii "i = %d\12\0"
        .text
        .globl        main
        .def        main;        .scl        2;        .type        32;        .endef
        .seh_proc        main
main:
        pushq        %rbp
        .seh_pushreg        %rbp
        movq        %rsp, %rbp
        .seh_setframe        %rbp, 0
        subq        $48, %rsp
        .seh_stackalloc        48
        .seh_endprologue
        call        __main
        movl        $10, -4(%rbp)
        movl        -4(%rbp), %eax
        leal        -1(%rax), %edx
        movl        %edx, -4(%rbp)
        subl        $1, -4(%rbp)
        movl        $-3, -4(%rbp)
        movl        -4(%rbp), %edx
        imull        -4(%rbp), %edx
        movl        %edx, %r8d
        movl        -4(%rbp), %edx
        leal        1(%rdx), %ecx
        movl        %ecx, -4(%rbp)
        imull        %r8d, %edx
        subl        %edx, %eax
        addl        $1, -4(%rbp)
        addl        %eax, -4(%rbp)
        movl        -4(%rbp), %eax
        movl        %eax, %edx
        leaq        .LC0(%rip), %rcx
        call        printf
        movl        $0, %eax
        addq        $48, %rsp
        popq        %rbp
        ret
        .seh_endproc
        .ident        "GCC: (GNU) 7.4.0"
        .def        printf;        .scl        2;        .type        32;        .endef

人造人 发表于 2019-10-22 21:49:13

$ gcc -g -Wall -o main main.c
main.c: In function ‘main’:
main.c:7:11: warning: operation on ‘i’ may be undefined [-Wsequence-point]
         i = i-- - --i * ( i = -3 ) * i++ + ++i;
         ^
main.c:7:11: warning: operation on ‘i’ may be undefined [-Wsequence-point]
main.c:7:11: warning: operation on ‘i’ may be undefined [-Wsequence-point]
main.c:7:11: warning: operation on ‘i’ may be undefined [-Wsequence-point]
main.c:7:11: warning: operation on ‘i’ may be undefined [-Wsequence-point]
$ ./main.exe
i = 36
$

人造人 发表于 2019-10-22 21:50:03

$ ./main.exe
i = 36
$

注意, i = 36

yuweb 发表于 2019-10-23 08:45:56

荒于嬉 发表于 2019-10-22 20:29
我用的dev 出来的结果是36 大概是编译环境不一样吧

我用的vc++6.0,那应该是编译环境不同的问题了
页: [1]
查看完整版本: i++与++i的计算问题