ftp://ftp.gnu.org/old-gnu/Manuals/gdb/html_node/gdb_toc.html
基本的使用就不用详细记录了,手指一动就出来了(或者直接help):
---------------------
gdb
file execFile
---------------------
gdb execFile
---------------------
run args ----> stop until breakpoint
info b
del bNum
b[reak] num
b[reak] [file:]function
watch varName
l[ist] num
l[ist] [file:]function
info thread
thread num
bt(backtrack)
f[rame] num
up
down
n[ext]
s[tep]
stepi
p[rint]
help breakpoints
回车 --> 重复上一个命令
1.设置多线程的调试模式
(gdb) help set scheduler-locking
Set mode for locking scheduler during execution.
off == no locking (threads may preempt at any time)
on == full locking (no thread except the current thread may run)
step == scheduler locked during every single-step operation.
In this mode, no other thread may run during a step command.
Other threads may run while stepping over a function call ('next').
2.设置list默认显示的行数
(gdb) show listsize
Number of source lines gdb will list by default is 10.
(gdb) set listsize 30
(gdb) show listsize
Number of source lines gdb will list by default is 30.
3.转储core文件 generate-core-file
gdb -p pid 切入一个进程,generate-core-file生成core文件,然后quit detach进程
4.可以使用examine命令(简写是x)来查看内存地址中的值。x命令的语法如下所示:
x/<n/f/u> <addr>
n、f、u是可选的参数。
n是一个正整数,表示需要显示的内存单元的个数,也就是说从当前地址向后显示几个内存单元的内容,一个内存单元的大小由后面的u定义。
f 表示显示的格式,参见下面。如果地址所指的是字符串,那么格式可以是s,如果地十是指令地址,那么格式可以是i。
u 表示从当前地址往后请求的字节数,如果不指定的话,GDB默认是4个bytes。u参数可以用下面的字符来代替,b表示单字节,h表示双字节,w表示四字 节,g表示八字节。当我们指定了字节长度后,GDB会从指内存定的内存地址开始,读写指定字节,并把其当作一个值取出来。
<addr>表示一个内存地址。
注意:严格区分n和u的关系,n表示单元个数,u表示每个单元的大小。
n/f/u三个参数可以一起使用。例如:
命令:x/3uh 0x54320 表示,从内存地址0x54320读取内容,h表示以双字节为一个单位,3表示输出三个单位,u表示按无符号十进制显示。