假设已定义:int a[100] 类型print a然后gdb将自动将其显示为数组:1, 2, 3, 4....但是,如果a作为参数传递给函数,那么gdb会将其视为普通的int指针,类型print a将显示:(int *)0x7fffffffdaa0.如果我想查看a数组,该怎么办?
izo*_*ica 74
看到这里.总之,你应该这样做:
p *array@len
Run Code Online (Sandbox Code Playgroud)
R..*_*R.. 17
*(T (*)[N])p 其中T是类型,N是元素的数量,p是指针.
使用该x命令.
(gdb) x/100w a
Run Code Online (Sandbox Code Playgroud)
正如@Ivaylo Strandjev 在这里所说,一般语法是:
print *my_array@len
# OR the shorter version:
p *my_array@len
Run Code Online (Sandbox Code Playgroud)
打印前 10 个字节的示例my_array:
print *my_array@10
Run Code Online (Sandbox Code Playgroud)
但是,如果这看起来像垃圾,因为它试图将值解释为字符,您可以强制使用不同的格式选项,如下所示:
print/x *my_array@10 = 十六进制print/d *my_array@10 = 有符号整数print/u *my_array@10 = 无符号整数print/<format> *my_array@10= 按照一般printf()风格的格式字符串打印,<format>以下是我的调试器中的一些真实示例,用于从uint8_t名为byteArray. 注意第一个有多丑,只有p *byteArray@16:
(gdb) p *byteArray@16
$4 = "\000\001\002\003\004\005\006\a\370\371\372\373\374\375\376\377"
(gdb) print/x *byteArray@16
$5 = {0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff}
(gdb) print/d *byteArray@16
$6 = {0, 1, 2, 3, 4, 5, 6, 7, -8, -7, -6, -5, -4, -3, -2, -1}
(gdb) print/u *byteArray@16
$7 = {0, 1, 2, 3, 4, 5, 6, 7, 248, 249, 250, 251, 252, 253, 254, 255}
Run Code Online (Sandbox Code Playgroud)
就我而言,最好的版本是我将数组打印为无符号整数的最后一个版本,因为它uint8_t毕竟是一个数组:
(gdb) print/u *byteArray@16
$7 = {0, 1, 2, 3, 4, 5, 6, 7, 248, 249, 250, 251, 252, 253, 254, 255}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
31127 次 |
| 最近记录: |