1.引言
在我的另一篇博客(链接:x86 64位的ubuntu环境下汇编(无优化)及函数调用栈的详解-CSDN博客)中详细分析了没有优化的情况下汇编的详解。在这篇文章中,尝试差分解析使用O2编译优化后生成的汇编代码,看看有啥不同。
2.源码
和链接中的源码是一样的。
#include<stdio.h>
typedef unsigned char uint8;
uint8 a = 0U;
uint8 b = 0U;
int main(int argn, char* argv[])
{
a = b + 1;
b = 1;
return 0;
}
汇编命令
g++ -S -O2 reorder_demo.cpp
3.汇编代码
如下:
.file "reorder_demo.cpp"
.text
.section .text.startup,"ax",@progbits
.p2align 4
.globl main
.type main, @function
main:
.LFB30:
.cfi_startproc
endbr64
movzbl b(%rip), %eax
movb $1, b(%rip)
addl $1, %eax
movb %al, a(%rip)
xorl %eax, %eax
ret
.cfi_endproc
.LFE30:
.size main, .-main
.globl b
.bss
.type b, @object
.size b, 1
b:
.zero 1
.globl a
.type a, @object
.size a, 1
a:
.zero 1
.ident "GCC: (Ubuntu 9.4.0-1ubuntu1~20.04.2) 9.4.0"
.section .note.GNU-stack,"",@progbits
.section .note.gnu.property,"a"
.align 8
.long 1f - 0f
.long 4f - 1f
.long 5
0:
.string "GNU"
1:
.align 8
.long 0xc0000002
.long 3f - 2f
2:
.long 0x3
3:
.align 8
4:
4.差分详解
首先看起来就比上篇文章中汇编简洁不少,结构上也有不同,
全局变量a和b的汇编内容放在了main函数内容之后。
剩余部分下回分解