[转载] gdb 调试打印完整字符串
背景
原文
https://blog.csdn.net/shuizhizhiyin/article/details/53227913
正文
在使用gdb调试过程中,经常需要查看变量的值,最常用的方法:
(gdb) print {变量名}
一般情况下,打印并不存在问题。但当一个字符串比较长时,打印出来的内容不完整,内容的最后为”…”
例如:
[cpp] view plain copy
(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"...
可以看到print显示的内容最后为”…“表示显示的内容并不完整。
问题:
那如何才能将长字符串显示完整呢?如果字符串比较长,又是依据什么来显示字符串呢?
首先,猜测打印的是一个固定长度的字符串,如果超过了默认的最大长度,那只打印默认最大长度的字符串内容,并在其后显示”…“表示打印内容不完整。
那这里的默认最大长度是多少呢?
通过以下命令可以查看:
[cpp] view plain copy
(gdb) show print elements
Limit on string chars or array elements to print is 200.
可以看到默认只会打印200个字符。这个可以通过前面的举例验证。
[cpp] view plain copy
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
刚好是200个字符。
其次,如何更改打印的字符串长度值?
可以通过命令:
[cpp] view plain copy
(gdb) set print elements 0
(gdb) show print elements
Limit on string chars or array elements to print is unlimited.
使打印的字符串长度不受限制。当然这里你也可以设置一个你需要的合理值。
例如:
[cpp] view plain copy
(gdb) set print elements 300
(gdb) show print elements
Limit on string chars or array elements to print is 300.
验证:再次打印前面例子中未完全显示的变量:
[cpp] view plain copy
(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] 来更改打印字符串的长度。
参考:
[cpp] view plain copy
(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