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