关于一个gdb的指令

info r显示的第二列和第三列表示什么,,不v知道怎么什么意思

img

不知道你这个问题是否已经解决, 如果还没有解决的话:
  • 你可以参考下这个问题的回答, 看看是否对你有帮助, 链接: https://ask.csdn.net/questions/244887
  • 我还给你找了一篇非常好的博客,你可以看看是否有帮助,链接:GDB调试打印中文, 解决显示不正常乱码问题
  • 除此之外, 这篇博客: 挂了而且gdb显示问号!中的 三 怎么破解问号 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

    其实通过上面过程我们了解到函数调用就是通过这种压栈和出栈调用的,其实还是蛮简单的。
    对于我们调试来说,如果因为程序的错误破坏了栈,但是有个地方数据不会破坏那就是寄存器的值,所以我们可以通过 打印rbp和rsp的值得到了最后调用栈的栈底和栈顶,但是这个这两个地址间的数据可能被破坏了,怎么办那,那就是以此地址为基准,继续对上找,就会找到其他函数的栈信息。
    使用到的命令如下:

    (gdb) p $rbp
    $40 = (void *) 0x7fffffffdff0
    (gdb) p $rsp
    $41 = (void *) 0x7fffffffdfe0
    (gdb) x /8ag $rbp
    0x7fffffffdff0:	0x7fffffffe010	0x400673 <b(int, char**)+46>
    0x7fffffffe000:	0x7fffffffe118	0x100000000
    0x7fffffffe010:	0x7fffffffe030	0x400695 <main(int, char**)+32>
    0x7fffffffe020:	0x7fffffffe118	0x100000000
    (gdb) 
    

    这样我们知道了,前面的调用栈原来是通过main函数调用到b函数,接着再调用到我们core的函数,从而定位core的大概位置。


如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^

每个寄存器的值,第二列是16进制格式,第三列是10进制格式。