1.最笨的方法
输出变量,或者简单的打印一句话。
2.工具一:gdb
3.工具二:strace(追踪)
#strace test
#strace -p <PID>
#strace -o output.log command (-o 选项将显示内容输出到文件中)
#strace command 2>&1 | grep map
#strace -f command (进程执行fork()之后,要跟踪fork()之后的进程)
#strace -tt command
#strace -t command (系统调用的执行时刻可以用-t或者-tt选项 -t为秒 -tt为毫秒)
4.工具三:objdump
objdump的选项 -S 、-l 十分方便。如果二进制文件中带调试信息,可以将源代码、文件名及行数与汇编代码对应显示。
#gcc -Wall -o0 -g teat.c -o test
#objdump -Sl --no-show-raw-insn
………………………………
/home/test/test.c:13
int m;
m = 5;
80483aa: movl $0x5,0xfffffff0(%ebp)
/home/test/test.c:14
m = 6;
………………………………
5.工具四:Valgrind (能检测内存的非法使用,对缓存、堆进行测评,检测线程冲突等)
#valgrind --leak-check=yes program
主要检测:内存双重释放、非法栈操作、内存泄漏
栈上生成的内存见无法检测到。
………………
未完待续