GDB调试查看内存数据

gdb查看内存数据

格式: x /nfu

说明:
x 是 examine 的缩写,意思是检查。

n表示要显示的内存单元的个数,比如:20

f表示显示方式, 可取如下值:

x 按十六进制格式显示变量。
d 按十进制格式显示变量。
u 按十进制格式显示无符号整型。
o 按八进制格式显示变量。
t 按二进制格式显示变量。
a 按十六进制格式显示变量。
i 指令地址格式
c 按字符格式显示变量。
f 按浮点数格式显示变量。

u表示一个地址单元的长度:

b表示单字节,
h表示双字节,
w表示四字节,
g表示八字节

测试

x /20xh 0x7fffffffe080

20是数量,x是16进制,h是双字。
在这里插入图片描述
用ctrl+x+a关闭wh窗口后,上键可以输入上次输入的GDB指令。

  • 13
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
以下是一个使用 GDB 调试 MySQL core 文件的案例: 1.获取 MySQL core 文件:在 MySQL 出现异常时,MySQL 会生成一个 core 文件,用于记录程序崩溃时的内存状态。从产生 core 文件的服务器上,将 core 文件下载到分析工具所在的机器上。 2.安装 GDB:GDB 工具是 Linux 下的一款调试工具,需要进行安装。如果未安装可以通过以下命令进行安装: ``` yum install gdb ``` 3.开启 core 文件的调试:默认情况下,Linux 禁止 core 文件的调试,需要手动进行开启。在 shell 终端中,执行以下命令: ``` ulimit -c unlimited ``` 4.使用 GDB 配置文件:为了方便进行调试,可以使用 GDB 的配置文件自动加载调试信息。在命令行中输入以下命令: ``` echo "set auto-load safe-path /" > ~/.gdbinit ``` 5.启动 GDB 调试:在命令行中输入以下命令启动 GDB 调试: ``` gdb /usr/sbin/mysqld /path/to/core ``` 其中,/usr/sbin/mysqld 是 MySQL 的可执行文件路径;/path/to/core 是 MySQL 生成的 core 文件路径。 6.分析 MySQL core 文件:在 GDB 调试模式下,可以使用一系列命令查看和分析 MySQL core 文件中的数据和信息。例如: - 使用 bt 命令查看函数调用栈: ``` (gdb) bt ``` - 查看当前 CPU 寄存器的值: ``` (gdb) info registers ``` - 查看当前栈帧的堆栈信息: ``` (gdb) x/20x $rsp ``` 通过以上命令可以定位 MySQL 程序的异常。例如,如果发现异常是由于某个函数中的指针出现了空指针引用,可以通过查看函数调用栈来定位异常所在的函数,然后查看相关的寄存器和堆栈信息来查找引起空指针异常的代码行。 总的来说,使用 GDB 工具对 MySQL core 文件进行分析和调试可以帮助开发人员更好地定位程序异常并进行修复。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值