gcc
Оптимизация GCC
Поиск…
Вступление
Компилятор GNU предлагает различные уровни оптимизации для процесса компиляции. Эти оптимизации используются для улучшения производительности кода и / или размера кода. Компиляция кода с оптимизацией, как правило, занимает больше времени.
Эта команда сообщает вам, какие оптимизации доступны в вашей системе: $ gcc -Q --help = optimizations
Ниже приведена подробная документация по параметрам управления оптимизацией:
Разница между кодами, скомпонованными с O0 и O3
Я написал простой код C foo.c
int main()
{
int i = 0;
int j = 0;
for (i = 0; i < 5; i++) {
j = i + 1;
}
return 0;
}
При компиляции с -O0, т.е. отключением всех оптимизаций компилятора
$ gcc -o foo.S foo.c -O0 -S
Я получил это:
.file "foo.c"
.text
.globl main
.type main, @function
main:
.LFB0:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
movl $0, -4(%rbp)
movl $0, -8(%rbp)
movl $0, -4(%rbp)
jmp .L2
.L3:
movl -4(%rbp), %eax
addl $1, %eax
movl %eax, -8(%rbp)
addl $1, -4(%rbp)
.L2:
cmpl $4, -4(%rbp)
jle .L3
movl $0, %eax
popq %rbp
.cfi_def_cfa 7, 8
ret
.cfi_endproc
.LFE0:
.size main, .-main
.ident "GCC: (GNU) 6.2.0"
.section .note.GNU-stack,"",@progbits
GCC взял на себя всю боль, чтобы преобразовать мой код в язык ассемблера дословно.
Но когда я скомпилировал свой код с O3, то есть с самым высоким уровнем оптимизации
Я получил это:
.file "foo.c"
.section .text.startup,"ax",@progbits
.p2align 4,,15
.globl main
.type main, @function
main:
.LFB11:
.cfi_startproc
xorl %eax, %eax
ret
.cfi_endproc
.LFE11:
.size main, .-main
.ident "GCC: (GNU) 6.2.0"
.section .note.GNU-stack,"",@progbits
GCC понял, что я просто рисовал и ничего не делал с переменными и циклом. Поэтому он оставил мне пустой заглушку без кода.
DAYUM!