串口打印调试信息的延时问题

           上上周在调试一个程序,程序运行的时候挂掉了。通过串口打印的调试信息,找到那个位置的代码却没发现问题,于是判断别的地方引起的异常。此时思考一个问题为什么程序异常的时候,调试信息没打出来呢? 答案就是串口输出是慢速设备,调试信息在串口缓存中,还没出到终端,此时程序已经运行到别的地方去了。所以导致看到的调试信息和程序异常的地方不一样最后是在打印调试信息延时一下才找到的bug。

        上周移植openssh到linux上,openssh可以从网络登录,但是传输文件的功能失败了。之前调试过两天,没有找到问题。通过调试信息是可以看到运行sftp-server的子进程很快就死了。加在sftp-server的调试信息并未打印。那几天一直在看进程方面的东西,waitpid返回后可以用宏获取子进程的退出的原因。便想查看下是什么原因导致的。在程序中加入调试信息从串口输出,定位到程序的某个函数中出错的。于再加了很多调试信息,程序在某个位置莫名其妙就死掉了,但是那个位置的代码看不出问题。看下把那个位置的代码屏蔽掉会咋样,结果程序通过了,输出sftp-server找不到libz库。这又是调试信息输出延时造成的。设置LD_LIBRARY_PATH后,程序正常了。

       总结:打印调试信息是慢速I/O行为,串口输出的调试信息会延时输出,当看到调试信息输出时,程序已经跑到别的地方了。

你可能感兴趣的:(ARM)