i++和++i

swofford posted @ 2010年9月30日 11:20 in C , 2221 阅读

在 Chito 开发者的一篇日志中,评论下面有人说传说中 ++i 比 i++ 的效率高,看 K&R 的书,上面的自增也是用 ++i,感觉有点好奇,就照葫芦画瓢,按这篇文章中的方法用 gcc 反了一下,却发现两者汇编代码一样……

test.c

1
2
3
4
5
6
7
8
9
10
11
#include <stdio.h>
 
int main(void)
{
    int i;
     
    i = 0;
    i++;
 
    return 0;
}

test2.c

1
2
3
4
5
6
7
8
9
10
11
#include <stdio.h>
 
int main(void)
{
    int i;
     
    i = 0;
    ++i;
 
    return 0;
}

 

反后的汇编代码

test.s

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
.file   "test.c"
    .def    ___main;    .scl    2;  .type   32; .endef
    .text
.globl _main
    .def    _main;  .scl    2;  .type   32; .endef
_main:
    pushl   %ebp
    movl    %esp, %ebp
    subl    $8, %esp
    andl    $-16, %esp
    movl    $0, %eax
    addl    $15, %eax
    addl    $15, %eax
    shrl    $4, %eax
    sall    $4, %eax
    movl    %eax, -8(%ebp)
    movl    -8(%ebp), %eax
    call    __alloca
    call    ___main
    movl    $0, -4(%ebp)
    leal    -4(%ebp), %eax
    incl    (%eax)
    movl    $0, %eax
    leave
    ret

 

test2.s

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
.file   "test.c"
    .def    ___main;    .scl    2;  .type   32; .endef
    .text
.globl _main
    .def    _main;  .scl    2;  .type   32; .endef
_main:
    pushl   %ebp
    movl    %esp, %ebp
    subl    $8, %esp
    andl    $-16, %esp
    movl    $0, %eax
    addl    $15, %eax
    addl    $15, %eax
    shrl    $4, %eax
    sall    $4, %eax
    movl    %eax, -8(%ebp)
    movl    -8(%ebp), %eax
    call    __alloca
    call    ___main
    movl    $0, -4(%ebp)
    leal    -4(%ebp), %eax
    incl    (%eax)
    movl    $0, %eax
    leave
    ret

具体如上了,比较了一下两者,是一样的,难道传说中的 ++i 比 i++ 效率高是假的? ==!!

我的水平很菜,若是有地方错了,欢迎各位指出。

Avatar_small
Garfileo 说:
2010年9月30日 13:18

嗯,赞较真!

那个话是我“传说”的。

不过,你用的例子,自然是看不出效率的。我那个传说,是有语境的。该用 ++i 的时候,如果用 i++,可能会导致代码行增多,所以我说前者效率低。

Avatar_small
Garfileo 说:
2010年9月30日 13:20

@Garfileo: s/前者效率低/前者效率高/g

Avatar_small
Qcf 说:
2010年10月02日 00:41

简单的整数自加这个会被优化掉吧
理论上说i++会产生一个临时变量浪费空间,所以能用++i就用++i吧

Avatar_small
_imfeng 说:
2010年10月05日 11:28

你可以在在看看vc的实现过程,看有无差异

Avatar_small
Kflayca 说:
2010年10月16日 11:07

http://hi.baidu.com/afeiqiang020/blog/item/015f0709f8656084d1581bae.html

//有int参数的表示后置自加
int operator ++ ()
{
return i += 1;
}

int operator ++(int i)
{
int k = i;
i += 1;
return k;
}


登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter