2.3.1测试
2.3.1测试
2.3.1测试
1 编辑并运行2.3.1中的代码,要求在不修改t2.c 和 t1.c中main函数中的代码的情况下,程序运行结果是你的后四位学号。提交代码和运行结果截图。
- 安装openEuler图形化界面
- t1.c
使用yum命令下载vim
yum install vim
如果无法连接,使用命令dhclient使用DHCP进行联网。
- t2.c
为使运行结果为学号,需要将g的值赋为1224即可:
2 网上学习objdump命令,提交不少于5篇博客链接和微信读书上的图书链接,并给出你认为最好的讲解资源的链接或图书名及章节
objdump学习链接:
https://www.pianshen.com/article/3362131908/
https://www.jianshu.com/p/a9a1d07302dc
https://www.cnblogs.com/baiduboy/p/7061365.html
https://linux265.com/course/linux-command-objdump.html
https://blog.csdn.net/q2519008/article/details/82349869
最好:
https://blog.csdn.net/yihaolovem/article/details/41877041(best)
- objdump的常用参数和用法:
--archive-headers
-a
显示档案库的成员信息,类似ls -l将lib*.a的信息列出。
-b bfdname
--target=bfdname
指定目标码格式。这不是必须的,objdump能自动识别许多格式,比如:
objdump -b oasys -m vax -h fu.o
显示fu.o的头部摘要信息,明确指出该文件是Vax系统下用Oasys编译器生成的目标文件。objdump -i将给出这里可以指定的目标码格式列表。
--debugging
-g
显示调试信息。企图解析保存在文件中的调试信息并以C语言的语法显示出来。仅仅支持某些类型的调试信息。有些其他的格式被readelf -w支持。
-e
--debugging-tags
类似-g选项,但是生成的信息是和ctags工具相兼容的格式。
--disassemble
-d
从objfile中反汇编那些特定指令机器码的section。
-D
--disassemble-all
与 -d 类似,但反汇编所有section.
--prefix-addresses
反汇编的时候,显示每一行的完整地址。这是一种比较老的反汇编格式。
-EB
-EL
--endian={big|little}
指定目标文件的小端。这个项将影响反汇编出来的指令。在反汇编的文件没描述小端信息的时候用。例如S-records.
-f
--file-headers
显示objfile中每个文件的整体头部摘要信息。
-H
--help
简短的帮助信息。
-i
--info
显示对于 -b 或者 -m 选项可用的架构和目标格式列表。
-j name
--section=name
仅仅显示指定名称为name的section的信息
-l
--line-numbers
用文件名和行号标注相应的目标代码,仅仅和-d、-D或者-r一起使用使用-ld和使用-d的区别不是很大,在源码级调试的时候有用,要求编译时使用了-g之类的调试编译选项。
-m machine
--architecture=machine
指定反汇编目标文件时使用的架构,当待反汇编文件本身没描述架构信息的时候(比如S-records),这个选项很有用。可以用-i选项列出这里能够指定的架构.
--reloc
-r
显示文件的重定位入口。如果和-d或者-D一起使用,重定位部分以反汇编后的格式显示出来。
--dynamic-reloc
-R
显示文件的动态重定位入口,仅仅对于动态目标文件意义,比如某些共享库。
-s
--full-contents
显示指定section的完整内容。默认所有的非空section都会被显示。
-V
--version
版本信息
--all-headers
-x
显示所可用的头信息,包括符号表、重定位入口。-x 等价于-a -f -h -r -t 同时指定。
3 用objdump分析第1步中的可执行文件和目标文件,提交你的分析截图以及如何和教材讲解内容对应的,比如obj文件的文件头,代码段,数据段等,可执行文件如何链接mysum的。
代码编译后的机器指令常常被放在代码段里,代码段名为".text";
已初始化的全局变量和已初始化的局部静态变量常常放在数据段里,数据段名为".data";
未初始化的全局变量和未初始化局部静态变量通常放在“.bss”段里,.bss在文件中不占据空间。
- objdump -h:查看文件段头信息
- objdump -f:显示文件头信息
- objdump -s:除了显示文件的全部Header信息,还显示他们对应的十六进制文件代码
- objdump -D:反汇编,与-d类似,但反汇编test中的所有section
t1.o文件:
-
文件头:
-
代码段:
-
数据段:
t2.o文件
-
文件头
-
代码段
可执行文件链接mysum:
1,链接器接收到输入文件
2,收集每个输入文件的段表,合成一个全局符号表,这张表里包含所有定义的符号
3,将多个输入文件合并,进行地址空间的分配,确定所有符号的具体地址
4,对每一个输入文件中需要重定位的符号重新定位到正确的地址处