Chinaunix首页 | 论坛 | 博客
  • 博客访问: 47194
  • 博文数量: 11
  • 博客积分: 383
  • 博客等级: 一等列兵
  • 技术积分: 133
  • 用 户 组: 普通用户
  • 注册时间: 2009-10-17 19:54
文章分类

全部博文(11)

文章存档

2012年(3)

2011年(8)

我的朋友

分类: LINUX

2011-08-31 08:28:05

昨天给项目的代码里面添加了一个小模块,作用是寻找IPv6数据包扩展头中的tcp或upd协议,并返回指向tcp或udp数据包包头的指针。模块很简单,本来打算一个小时都搞定,结果却整整花费了4个多小时的时间。出现的错误很让人觉得诡异,在子函数返回之前,待返回的指针地址没有问题,但是主函数获得的返回地址只有低4字节(64位机)相同,高4字节竟然是“FFFFFFFF”。当时就崩溃了,找hints帮忙gdb,结果发现汇编代码中,在函数返回之前,寄存器eax中的值是正确的;但是函数返回后,eax中的值高4位被自动截短。经过一段时间痛苦的挣扎之后,感觉是编译器自动将char*类型指针转化为了void*类型指针。忽然想到hints提醒的一句话“你这可能是警告信息没处理的原因”,于是耐心把警告信息处理了一下,发现原来是隐式声明了子函数,忘记包含头文件了。解决了警告信息之后,bug成功消除。所以,在这里告诫一下自己,“不要忽视编译器的任何抱怨,否则会死的很惨。”
阅读(1633) | 评论(0) | 转发(1) |
0

上一篇:ubuntu网络配置

下一篇:惨痛的腾讯面试

给主人留下些什么吧!~~