Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1804269
  • 博文数量: 274
  • 博客积分: 2366
  • 博客等级: 大尉
  • 技术积分: 1880
  • 用 户 组: 普通用户
  • 注册时间: 2007-04-22 09:37
文章分类

全部博文(274)

文章存档

2022年(1)

2020年(10)

2019年(7)

2018年(18)

2017年(26)

2016年(32)

2015年(43)

2014年(30)

2013年(44)

2012年(36)

2011年(17)

2010年(10)

分类: LINUX

2020-06-17 10:22:08

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