免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1670 | 回复: 2
打印 上一主题 下一主题

[Linux] gdb显示怪异问题,急死人啊。 [复制链接]

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-26 16:29 |只看该作者 |倒序浏览
本帖最后由 cxytz01 于 2012-12-26 16:41 编辑

所有 AAA.XX  格式都替换成AAA. "[" +  i + "]". XX,  cu不可以正常显示 "[  + ]" 。

我有一个网络程序,流程如下

strcut AAA {

    char to[2048];
    char *tooptr;            // tooptr 指向to的开头
}AAA[1000];

AAA\[i\].tooptr = AAA\[i\].to;

for(i = 0; i < 1000; i++) {  /* 发送to到套接口 */

   write(fd, AAA.tooptr, 2048   );

}

假设to的内容是【a  1999个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[0]                                      --to buff地址
$19 = 0x674dc8 "a", '1' <repeats 199 times>...             ---这里怎么回事,才打这么点,应该和上面一样才对

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



(gdb) print &gt_sockfd.to                                           --to buff地址同上
$25 = (char (*)[2048]) 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[199]
$31 = 49 '1'
(gdb) print gt_sockfd.tooptr[200]
$32 = 49 '1'
(gdb) print gt_sockfd.tooptr[201]
$33 = 49 '1'




如果我使用
(gdb) print *gt_sockfd.tooptr@2048
$34 = "a", '1' <repeats 2045 times>, "b"                   ---则正常显示


实在没辙了。





论坛徽章:
0
2 [报告]
发表于 2012-12-26 19:02 |只看该作者
神描述,没看懂。

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
3 [报告]
发表于 2012-12-26 20:08 |只看该作者
结贴,绕过此问题搞定了。匆匆写的,没描述清楚。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP