使用gdb

1、设置断点,在源程序第16 行处

(gdb)break 16 
Breakpoint 1 at 0x8048496: file tst.c, line 16.

2、设置断点,在函数func()入口处。

(gdb)break func 
Breakpoint 2 at 0x8048456: file tst.c, line 5.

3、查看断点信息。

(gdb)info break 
Num Type Disp Enb Address What
1 breakpoint keep y 0x08048496in main at tst.c:16
2 breakpoint keep y 0x08048456 in func at tst.c:5

4、

(gdb)run ——————运行程序 r
(gdb)next ——————单条语句执行。 n
(gdb)continue ——————继续运行程序 c

5、查看所有参数

(gdb)in all
info local 查看当前变量

6、打印变量i 的值(gdb)print i p i

$1 = 134513808
(gdb) p g_uiTblmIdSwitchControl 
$1 = -1 
(gdb) p g_uiTblmLogSwitchControl = 1 
$2 = 1 
(gdb) p g_uiTblmIdSwitchControl = 74 x 
$3 = 74 
(gdb) q

7、查看函数堆栈

(gdb)bt
#0 func (n=250) at tst.c:5
#1 0x080484e4 in main () at tst.c:24
#2 0x400409ed in __libc_start_main () from /lib/libc.so.6

8、退出函数

(gdb)finish
Run till exit from #0 func (n=250) at tst.c:5
0x080484e4 in main () at tst.c:24
24 printf("result[1-250] = %d \n", func(250) );
Value returned is $6 = 31375

9、 退出gdb
(gdb)quit

10、查看内存内容

x /160xb 0x43964d80

该命令的具体语法格式为 x<n/f/u><addr> n、f、u是可选参数。

n 是一个正整数,表示显示内存的长度,也就是说从当前地址向后显示几个地址的内容。
f 表示显示的格式,参见上面。如果地址所指的是字符串,那么格式可以是s,如果地十是指令地址,那么格式可以是i。
u 表示从当前地址往后请求的字节数,如果不指定的话,GDB默认是4个bytes。u参数可以用下面的字符来代替,b表示单字节,h表示双字节,w表示四字 节,g表示八字节。当我们指定了字节长度后,GDB会从指内存定的内存地址开始,读写指定字节,并把其当作一个值取出来。

<addr>表示一个内存地址。
n/f/u三个参数可以一起使用。例如:命令:x/3uh 0x54320 表示,从内存地址0x54320读取内容,h表示以双字节为一个单位,3表示三个单位,u表示按十六进制显示。

输出格式
一般来说,GDB会根据变量的类型输出变量的值。但你也可以自定义GDB的输出的格式。例如,你想输出一个整数的十六进制,或是二进制来查看这个整型变量的中的位的情况。要做到这样,你可以使用GDB的数据显示格式:

x 按十六进制格式显示变量。
d 按十进制格式显示变量。
u 按十六进制格式显示无符号整型。
o 按八进制格式显示变量。
t 按二进制格式显示变量。
a 按十六进制格式显示变量。
c 按字符格式显示变量。
f 按浮点数格式显示变量。
(gdb) p i
$21 = 101 

(gdb) p/a i
$22 = 0x65

(gdb) p/c i
$23 = 101 'e'

(gdb) p/f i
$24 = 1.41531145e-43

(gdb) p/x i
$25 = 0x65

(gdb) p/t i
$26 = 110010

11、查看数据结构

p *(struct link_map *)0x7fab515fe000

12、gdb -p 子进程

13、watch *(int*)监控4字节地址 用户态修改

14、如果core文件出现两个线程,如

[New LWP 221856]
[New LWP 217511]

t 2
bt
就可以看到第二个线程对应的调用栈,thread apply all where 查看所有线程

15、强制调用函数

使用call或print命令 直接调用函数执行

16、生成内核转存文件

gcore 命令生成core文件 

17、函数短接

gdb下输入:
b LSPIC_LinkAlmPer_InsLinkAlm
commands
return (unsigned int)0
c
end

18、观测点

watch len,可以加观测点,值变化的话会有打印信息,或者告警

 19、gdb下需要输入参数

set args prama1 prama2

 

posted @ 2019-08-26 17:17  行木辛  阅读(631)  评论(0编辑  收藏  举报