linux在当前目录下新建文件需要的命令是mkdir 文件名
然后进入新建的文件的命令是cd 文件名 返回上一层是cd ..
新建一个c语言程序的过程是先打开vim 编译器 ,然后写完后进行输入esc 输入:w进行保存 再输入:q进行退出然后进行编译链接,主要的命令是gcc -c 文件名.c。编译结束,然后gcc -o 文件名 文件名.o 链接结束。执行程序的主要命令是./文件名 即可
接下来要说的是进行查看汇编代码
前期准备
cd 文件名
使用不带编译优化的
下面所指的文件名是建好的c语言文件
gcc -O0 文件名.c -m32 -g -o 文件名
反汇编
objdump -S(一定注意大写) 文件名>文件名.txt
用 vi编辑器打开即可看到反汇编的内容
第一步启用gdb
具体操作 (gdb)文件名
第二步 设置断点
具体操作 (gdb)break main(这是在main函数的地方设置的断点)
另一种方法:(gdb)break 文件名.c:行数(在某一行设置断点)
第三步 运行程序
具体操作(gdb) run
第四步 执行一条指令
具体操作 (gdb)si(执行一条指令)s(执行一条语句)
第五步 查看定点寄存器的内容
具体操作(gdb)i r
第六步 查看指定的寄存器的内容
具体操作(gdb)i r esp ebp //esp栈顶寄存器 ebp 栈底寄存器
第七步 按字节显示当前栈帧内容,观察栈中数据
具体操作(gdb)x/yxb $esp //y=(ebp)-(esp)+4
第八步按4字节显示当前栈帧内容,观察栈中数据
具体操作(gdb)x/zxw $esp //z=((ebp)-(esp)+4)/4
第九步
退出:(gdb)quit