前段时间调试代码时发现 程序直接运行的结果怎么都不正确, 但使用gdb单步执行时结果却总是正确的。
最开始以为使用gdb单步执行与程序直接运行的区别无非就是对多线程的影响,可查来查去没有发现线程安全问题。
后来仔细梳理了现象并啃了一遍代码后才发现,gdb单步执行也会对网络io产生影响。
我当时的现象就是:
直接运行时,读到的HTTP响应总是只有head没有body;
gdb单步执行时,却能全部读到。
原因就是,我当时为了调试代码方便,读非阻塞的fd时只读了一次就直接返回了,虽然我提供的buffer足够大,但因为服务端在发送响应时是先发了head,然后再发body,有短暂的延时。所以,程序直接运行时因为执行的很快,读数据时接收缓冲区里只有head,body还在传输途中,就只读到了head;而gdb单步执行时,因为人为一步一步执行,等执行到读数据时,head和body都已经接收到缓冲区了,所以同样是只读一次却能全部读到。