cxytz01 发表于 2012-12-26 16:29

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 &gt_sockfd.to                                    --to buff地址
$19 = 0x674dc8 "a", '1' <repeats 199 times>...             ---这里怎么回事,才打这么点,应该和上面一样才对

(gdb)print &gt_sockfd.to                                 ---看都没有'\0'截断,为什么后面的打不出来?
$28 = 0x674e8e '1' <repeats 200 times>...
(gdb)print &gt_sockfd.to
$29 = 0x674e90 '1' <repeats 200 times>...
(gdb)print &gt_sockfd.to
$30 = 0x674e91 '1' <repeats 200 times>...



(gdb) print &gt_sockfd.to                                           --to buff地址同上
$25 = (char (*)) 0x674dc8

(gdb) print /x &gt_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"                   ---则正常显示


实在没辙了。





lrita 发表于 2012-12-26 19:02

神描述,没看懂。

cxytz01 发表于 2012-12-26 20:08

结贴,绕过此问题搞定了。匆匆写的,没描述清楚。
页: [1]
查看完整版本: gdb显示怪异问题,急死人啊。