Linux下的调试工具说多也多,说少也少,尤其对于嵌入式开发来说,找个顺手、好用、满足各方面要求的工具还真不容易。这里列的一些工具也只是能满足一些简单需求,要达到产品级的质量,还是得靠商业工具(一个或多个配合使用)+足够的人力+细心和耐心 ^_^
【2】
名称:YAMD
功能:
1、查找 c 和 c++ 中动态的、与内存分配有关的问题
参考文献:
【1】
【2】
【3】
名称:electric fence
功能:
1、检测内存泄露
2、检查数据越界
3、分配受保护的内存
参考文献:
【1】
【2】
【3】
【4】
名称:strace
功能:
1、显示用户空间程序发出的系统调用
2、显示调用的参数和返回值
【5】
名称:gdb
功能:
1、启动程序
2、使程序能够停止在指定文件的指定位置
3、查看程序变量值
4、改变程序执行期间的相关变量、路径等
【7】
名称:mtrace
功能:
1、检测一些内存分配和泄漏的失败等
参考文献:
【1】
【2】
【3】
【8】
名称:binutil
说明:binutil为一个工具集合,包含如下的工具。
addr2line 把程序地址转换为文件名和行号。在命令行中给它一个地址和一个可执行文件名,它就会使用这个可执行文件的调试信息指出在给出的地址上是哪个文件以及行号。
ar 建立、修改、提取归档文件。归档文件是包含多个文件内容的一个大文件,其结构保证了可以恢复原始文件内容。
as 主要用来编译GNU C编译器gcc输出的汇编文件,产生的目标文件由连接器ld连接。
c++filt 连接器使用它来过滤 C++ 和 Java 符号,防止重载函数冲突。
gprof 显示程序调用段的各种数据。
ld 是连接器,它把一些目标和归档文件结合在一起,重定位数据,并链接符号引用。通常,建立一个新编译程序的最后一步就是调用ld。
nm 列出目标文件中的符号。
objcopy 把一种目标文件中的内容复制到另一种类型的目标文件中.
objdump 显示一个或者更多目标文件的信息。显示一个或者更多目标文件的信息。使用选项来控制其显示的信息。它所显示的信息通常只有编写编译工具的人才感兴趣。
ranlib 产生归档文件索引,并将其保存到这个归档文件中。在索引中列出了归档文件各成员所定义的可重分配目标文件。
readelf 显示ebf格式可执行文件的信息。
size 列出目标文件每一段的大小以及总体的大小。默认情况下,对于每个目标文件或者一个归档文件中的每个模块只产生一行输出。
strings
打印某个文件的可打印字符串,这些字符串最少4个字符长,也可以使用选项-n设置字符串的最小长度。默认情况下,它只打印目标文件初始化和可加载段中的
可打印字符;对于其它类型的文件 它打印整个文件的可打印字符,这个程序对于了解非文本文件的内容很有帮助。
strip 丢弃目标文件中的全部或者特定符号。
libiberty 包含许多GNU程序都会用到的函数,这些程序有: getopt, obstack, strerror, strtol 和 strtoul.
libbfd 二进制文件描述库.
libopcodes 用来处理opcodes的库, 在生成一些应用程序的时候也会用到它, 比如objdump.Opcodes是文本格式可读的处理器操作指令.
功能:程序调试、归档等
参考文献:
【9】
名称: Purify
功能:内存检查工具
参考文献:
【11】
名称:splint
说明:splint是一个动态检查C语言程序安全弱点和编写错误的程序
功能:
1、空引用错误
2、未定义的变量错误
3、类型错误
4、内存检查
参考文献:
【1】
【2】
【12】
名称:boundercheck
功能:检查内存泄露
【13】
名称:valgrind
功能:
1、检查内存错误
参考文献: