(3)调试器:gdb
1.GNU计划的工具:内核调试KGDB
2.程序的错误分类:编译时错误,语法错误 ,运行时错误:内存错误,逻辑错误
3.gdb的功能:运行程序;设置断点;查看变量值
4.例如有一个hello.c文件,则执行命令
gcc -g hello.c -o hello
gcc gdb
5.基础命令
–tui:图形界面化
layout:用于分割窗口,可以一边查看代码,一边测试。主要有以下几种用法:
layout asm 显示汇编程序
layout src 显示源码窗口
layout regs:显示源代码/汇编和寄存器窗口
layout split:显示源代码和汇编窗口
layout next:显示下一个layout
layout prev:显示上一个layout
Ctrl + L:刷新窗口
Ctrl + x,再按1:单窗口模式,显示一个窗口
Ctrl + x,再按2:双窗口模式,显示两个窗口
Ctrl + x,再按a:回到传统模式,即退出layout,回到执行layout之前的调试窗口。
run 运行命令
break+行号
break+函数名
break+行号 if条件
info break 查看断点信息
delete+断点编号
enable+断点编号
disable+断点编号
单步执行:step next
step 可以进入子函数
next 不可以进入子函数
(4)工程管理器:make
—实现自动编译(根据makefile实现)
1.编译很多个文件(类型不同、存放不再不同目录、资源文件使用)组成的软件代码结构 --实现自动编译(根据makefile文件的内容进行)。
“自动编译”:
(1)根据makefile文件的内容进行自动编译;
(2)根据文件的时间戳来判断文件是否需要编译。
单个.c — gcc hello.c -o hello;
多个.c – gcc .c -o hello(所有的.o文件存放在hello中)。
2、Make读取makefile内容(如何编写makefile文件?)
(1)makefile是个脚本文件(批处理)
(2)makefile语法: 目标、依赖、命令
格式:
目标:依赖
换行输命令(有时可能需要按Tab)。
可以理解为执行命令,依赖这个文件,最终生成目标。
(4)makefile执行顺序:自上向下,当你的目标依赖的文件又是有一个目标时,会先跳转到该目标去执行相关命令。
例:
结果为
看上去是从后往前执行命令了。
首先我们是创建了一个hello文件
需要生成该文件的makefile文件,从前往后执行,makefile中第一行的依赖(hello:hello.o)为第二行的目标(hello.o:hello.c),也就是说hello.o还没生成,所以系统自动跳转,先执行了第二行命令。
(5)执行make,假设文件中有多个makefile文件,则使用命令——make -f 文件名
(6)伪目标:执行命令,不生成对应的文件。.PHONY:
伪目标是用来简化操作的,提前将命令用一个简单的单词申明好,这里就要提到另外一点makefile的执行
(7)makefile的执行
makefile一般只会执行一次,连续执行会有提示
这是因为makefile是根据文件的时间戳来判断文件是否需要编译的,所以有两种方法可以解决
(a)更新你的makefile
(b)删除makefile生成文件(目标)
(8)makefile文件执行后会把命令全部显示出来
解决方法就是在每行命令前加个@,有时会担心命令是否执行,则可以加一段命令echo用来输出一段话
(9)makefile中存在内置变量,可以让输入更加简便。
例$@代表依赖
3、为什么将.c文件先编译生成.o文件,再由.o文件生成可执行文件?
前提:源文件到可执行文件:预处理、编译、汇编、链接(1s)
gcc hello.c -0 hello 4s
cal:main.c add.c sub.c div.c mul.c
gcc .c -0 cal
假设修改了add.c — make: 20s
假设修改了add.c — make:(.c -->.0) 第一次:20s,第二次:4s+4s=8s。
4、功能目录管理软件代码:
1.Scripts目录头文件Makefile:定义变量,供其他makefile使用。
2.总控Makefile:进入各个功能目录执行make,并将所有.o文件链接生成可执行文件。
3.功能目录Makefile:将功能目录下的源文件编译生成目标文件.o。
例:执行多文件
源文件包含add,sub,mul,div四个文件
makefile文件(两种方式)
(1)
(2)