命令分析
1.命令:
gcc -Wall -Og -c static-local.c
gcc -Wall -Og -o prog main.o sum.o
gcc -Wall -Og -S main.c
运行结果
分析
gcc -Wall -Og -c static-local.c是编译并优化,汇编该代码为static-local.o的二进制文件。
gcc -Wall -Og -o prog main.o sum.o是把main.o 和sum.o链接成prog的可执行文件。
gcc -Wall -Og -S main.c是编译并优化生成main.s文件。
2.命令:
objdump -dx main.o
运行结果
分析
对整个main.o文件进行反汇编
3.命令:
objdump -dx -j .data main.o
运行结果
分析
输出反汇编代码中.data段的信息。
4. 命令:
readelf -s main.o
运行结果
分析
查看main.o文件中所有的符号,Value的值是符号的地址。
5.命令:
objdump -dx sum.o
运行结果
分析
对整个sum.o文件进行反汇编
6.命令:
objdump -dx -j .data sum.o
运行结果
分析:输出反汇编代码中.data段的信息。
7. 命令:
readelf -s sum.o
运行结果
分析
查看sum.o文件中所有的符号,Value的值是符号的地址。
8.命令:
objdump -dx -j .data prog
运行结果
分析
反汇编prog输出.data段的信息
类型失配实例
10.命令:
gcc -Wall -Og -o mismatch mismatch-main.c mismatch-variable.c
运行结果
分析
编译链并优化,生成mismatch的可执行文件。
外部说明符的使用
11.命令:
gcc -Wall -Og -o global global-c1.c global-c2.c
运行结果
分析
编译链并优化,生成global的可执行文件。
12.命令:
ar rcs libvector.a addvec.o multvec.o
运行结果
分析
使用ar创建静态库
编译时链接的静态库
13.命令:
gcc -Wall -Og -static -o prog2c main2.o -L. -lvector
运行结果
分析
编译为静态程序prog2c
14.命令:
objdump -d prog2c
运行结果
分析
Prog2c文件非常大,因为此时是静态的程序,因为它已经把各种依赖的函数,都包含进来了。跑prog2c不需要依赖任何库了。
在加载时链接的共享库
15.命令:
gcc -Wall -Og -o prog2l main2.o ./libvector.so
运行结果
分析
编译链并优化,生成prog2l的可执行文件。依赖库libvector.so
16. 命令:
objdump -dx main2.o
运行结果
分析
反编译main2.o文件
17. 命令:
objdump -dx prog2l
运行结果
分析
反编译prog2l文件
18. 命令:
objdump -xs -j .data -j .got prog2l
运行结果
分析
反编译prog2l文件,显示.data和.got段的信息。
运行时链接的共享库
19.命令:
gcc -Wall -Og -rdynamic -o prog2r dll.c -ld
运行结果
分析
-rdynamic 用来通知链接器将所有符号添加到动态符号表中
20.命令:
gcc -Wall -Og -shared -fpic -o libvector.so addvec.c multvec.c
运行结果
分析
-shared 动态编译
21.命令:
objdump -xd libvector.so
运行结果
分析
反编译
22.命令:
objdump -xRr -j .data -j .got -j .got.plt -j rela.dyn -j rela.plt libvector.so > libvectordata-relo.d
运行结果
分析
反编译,显示.data .got .got.plt rela.plt 段的信息。