如何解决GDB输出中的异常行为
因此,我开始学习如何使用GDB,并且在输出中出现了一些意外行为。
我正在以下程序上运行GDB
#include <stdio.h>
#include <stdlib.h>
int main() {
unsigned int value1,abs_value1,abs_value2,abs_value3;
int value2,value3;
char myarray[10];
printf("Enter 10 characters:");
fgets(myarray,11,stdin);
printf("Enter an integer between 0 and 10,000:");
scanf("%d",&value1);
abs_value1 = abs(value1);
printf("Enter an integer between -10,000 and 0:");
scanf("%d",&value2);
abs_value2 = abs(value2);
printf("Enter an integer between -10,000 and 10,&value3);
abs_value3 = abs(value3);
// set breakpoint here
}
我输入的值是...
value1 = 578
value2 = -1123
value3 = 999
在前两个测试一些命令时,我发现了一些有趣的行为
x/1d &abs_value3 : -25
x/1d &abs_value1 : 66
在最后两个回合中,我开始获得一些预期的输出
x/1d &abs_value3 : 999
x/1d &abs_value1 : 578
我在所有测试中都使用了相同的程序,并且以相同的方式运行测试,但是我一点也不担心输出中的不一致。我希望这是有道理的,我只是想知道是什么原因
为澄清起见,我正在发布屏幕截图。突出显示的部分显示了正在使用的相同命令,但稍后会有不同的输出
解决方法
我一点也不担心输出中的不一致。
您不是在讲整个故事,因此很难猜测发生了什么。
以下命令:x/1d addr
告诉GDB检查位于addr
的一个(内存)单元,并将其打印为十进制数字。
但是这个单位有多大?
没有明确的说明,它依赖 先前执行的命令。来自gdb documentation:
每次用x指定单位大小时,该大小将在下次使用x时成为默认单位。
因此,鉴于您的“不一致”输出:
x/1d &abs_value3 : -25
x/1d &abs_value3 : 999
并且还知道999 == 0x3e7
和(signed char)0xe7 == -25
,我们可以推断出在使用x/1b
之前您使用x/1d
会产生第一个输出,但没有使用{{ 1}}在x/1b
之前产生第二个输出。
为避免混淆自己,请始终指定要检查的尺寸。
如果您使用过x/1d
(或x/dw
,但默认值为1),则每次都会打印相同的输出。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。