我写了这个简单的C程序:
int main() {
int i;
int count = 0;
for(i = 0; i < 2000000000; i++){
count = count + 1;
}
}
Run Code Online (Sandbox Code Playgroud)
我想看看gcc编译器如何优化这个循环(显然添加1 2000000000次应该是"一次添加2000000000 ").所以:
GCC test.c的,然后time就a.out给出了:
real 0m7.717s
user 0m7.710s
sys 0m0.000s
Run Code Online (Sandbox Code Playgroud)
$ gcc -O2 test.c 然后time ona.out`给出:
real 0m0.003s
user 0m0.000s
sys 0m0.000s
Run Code Online (Sandbox Code Playgroud)
然后我用两个人拆开了gcc -S.第一个似乎很清楚:
.file "test.c"
.text
.globl main
.type main, @function
main:
.LFB0:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
movq %rsp, %rbp
.cfi_offset 6, …Run Code Online (Sandbox Code Playgroud)