gdb显示怪异问题,急死人啊。
本帖最后由 cxytz01 于 2012-12-26 16:41 编辑所有 AAA.XX格式都替换成AAA. "[" +i + "]". XX,cu不可以正常显示 "[+ ]" 。
我有一个网络程序,流程如下
strcut AAA {
char to;
char *tooptr; // tooptr 指向to的开头
}AAA;
AAA\.tooptr = AAA\.to;
for(i = 0; i < 1000; i++) {/* 发送to到套接口 */
write(fd, AAA.tooptr, 2048 );
}
假设to的内容是【a1999个1 b】
-------------------------------------------
问题来了, 不停的发送过程中,套接口肯定会在某处阻塞。 如果阻塞了,我就select(fd, ...), 然后再发送。 结果阻塞之后发送出去的是【a 127个1,加下一个i的a n个1】
例子:
阻塞于第94个i,0~93个i正常发送,发送结果为【a 1999个1 b】。
等待套接口可用后,发送第94个i,结果发送为【a 127个1 b】,再加上95个i的,【a n个1】 总共2048bytes。
使用gdb调试,奇怪的事情发生了:
(gdb) print i --第94个i
$15 = 94
(gdb) print gt_sockfd.to --to buff是【a 2045个1 b】
$16 = "a", '1' <repeats 2045 times>, "b"
(gdb) print >_sockfd.to --to buff地址
$19 = 0x674dc8 "a", '1' <repeats 199 times>... ---这里怎么回事,才打这么点,应该和上面一样才对
(gdb)print >_sockfd.to ---看都没有'\0'截断,为什么后面的打不出来?
$28 = 0x674e8e '1' <repeats 200 times>...
(gdb)print >_sockfd.to
$29 = 0x674e90 '1' <repeats 200 times>...
(gdb)print >_sockfd.to
$30 = 0x674e91 '1' <repeats 200 times>...
(gdb) print >_sockfd.to --to buff地址同上
$25 = (char (*)) 0x674dc8
(gdb) print /x >_sockfd.to --to buff地址同上
$26 = 0x674dc8
(gdb) print gt_sockfd.tooptr --tooptr指针指向了to buff,地址是一样的,但是,
$20 = 0x674dc8 "a", '1' <repeats 199 times>... --同样也没有'\0'截断后面的也打不出来
(gdb) print gt_sockfd.tooptr
$31 = 49 '1'
(gdb) print gt_sockfd.tooptr
$32 = 49 '1'
(gdb) print gt_sockfd.tooptr
$33 = 49 '1'
如果我使用
(gdb) print *gt_sockfd.tooptr@2048
$34 = "a", '1' <repeats 2045 times>, "b" ---则正常显示
实在没辙了。
神描述,没看懂。 结贴,绕过此问题搞定了。匆匆写的,没描述清楚。
页:
[1]