在使用gdb调试过程中,经常需要查看变量的值,最常用的方法:
(gdb) print {变量名}
一般情况下,打印并不存在问题。但当一个字符串比较长时,打印出来的内容不完整,内容的最后为"..."
例如:
- (gdb) p (char*)0x23b744a98
- $19 = 0x23b744a98 "obbs:S:1.3:{[{1,772830,772830,35513000054164,45514000069401,0,0,15525034,1,7778,-1,0,0,1,1,[{1,7,7,9005,-41600,10402},{1,7,7,9006,-41600,10402},{1,7,7,4002,-1,10402},{1,7,7,4005,17400,10402},{1,7,7,40"...
问题:
那如何才能将长字符串显示完整呢?如果字符串比较长,又是依据什么来显示字符串呢?
首先,猜测打印的是一个固定长度的字符串,如果超过了默认的最大长度,那只打印默认最大长度的字符串内容,并在其后显示"..."表示打印内容不完整。
那这里的默认最大长度是多少呢?
通过以下命令可以查看:
- (gdb) show print elements
- Limit on string chars or array elements to print is 200.
- obbs:S:1.3:{[{1,772830,772830,35513000054164,45514000069401,0,0,15525034,1,7778,-1,0,0,1,1,[{1,7,7,9005,-41600,10402},{1,7,7,9006,-41600,10402},{1,7,7,4002,-1,10402},{1,7,7,4005,17400,10402},{1,7,7,40
其次,如何更改打印的字符串长度值?
可以通过命令:
- (gdb) set print elements 0
- (gdb) show print elements
- Limit on string chars or array elements to print is unlimited.
例如:
- (gdb) set print elements 300
- (gdb) show print elements
- Limit on string chars or array elements to print is 300.
验证:再次打印前面例子中未完全显示的变量:
- (gdb) p (char*)0x23b744a98
- $30 = 0x23b744a98 "obbs:S:1.3:{[{1,772830,772830,35513000054164,45514000069401,0,0,15525034,1,7778,-1,0,0,1,1,[{1,7,7,9005,-41600,10402},{1,7,7,9006,-41600,10402},{1,7,7,4002,-1,10402},{1,7,7,4005,17400,10402},{1,7,7,4006,-41600,10402},{1,7,7,4007,0,-1},{1,7,7,4015,17400,10402}]}]}"
OK.这次打印已经能显示整个字符串所有内容。
总结:
使用set print elements [n] 来更改打印字符串的长度。
参考:
- (gdb) help set print elements
- Set limit on string chars or array elements to print.
- "set print elements 0" causes there to be no limit.
gdb打印完整字符串内容
在使用gdb进行程序调试时,经常遇到打印字符串内容的情况。但是很遗憾,缺省情况下,当待显示的字符串比较长时,gdb只会显示部分字符串内容,给程序的调试带来不便。
通过如下命令可以实现gdb中打印完整字符串内容:
set print element 0
Here is an example. If a program says
int *array = (int *) malloc (len * sizeof (int));
you can print the contents of array with
p *array@len