GDB格式化输出显示结构体

时间:2025-04-22 07:29:55

GDB格式化输出显示结构体

GDB输出显示结构体,使用print命令,如下:

(gdb) p *struct_ptr
$326 = {elem = {index = 178, len = 21845, ndescs = 1, out_num = 2, in_num = 1, in_addr = 0x55555cf38d00, 
    out_addr = 0x55555cf38d08, in_sg = 0x55555cf38d18, out_sg = 0x55555cf38d28}, vq = 0x7fffec3b8010, 
  cmd_hdr = {type = 519, flags = 1, fence_id = 746767, ctx_id = 3, padding = 0}, error = 0, 
  finished = false, next = {tqe_next = 0x55555cf38e10, tqe_circ = {tql_next = 0x55555cf38e10, 
      tql_prev = 0x555557439da8}}}

这样显示出来的结构体,很难在调试的时候一眼捕捉到有用的信息,往往需要仔细找找。

GDB提供了格式化输出显示结构体的选项,set print pretty off, 这个选项的默认是关闭的。打开该选项再次打印结构体,结果如下:

(gdb) set print pretty on
(gdb) p *cmd
$327 = {
  elem = {
    index = 178, 
    len = 21845, 
    ndescs = 1, 
    out_num = 2, 
    in_num = 1, 
    in_addr = 0x55555cf38d00, 
    out_addr = 0x55555cf38d08, 
    in_sg = 0x55555cf38d18, 
    out_sg = 0x55555cf38d28
  }, 
  vq = 0x7fffec3b8010, 
  cmd_hdr = {
    type = 519, 
    flags = 1, 
    fence_id = 746767, 
    ctx_id = 3, 
    padding = 0
  }, 
  error = 0, 
  finished = false, 
  next = {
    tqe_next = 0x55555cf38e10, 
    tqe_circ = {
      tql_next = 0x55555cf38e10, 
      tql_prev = 0x555557439da8
    }
  }
}

以这样的方式显示结构体会友好很多。调试起来结构体的成员一目了然。

相关文章