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

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

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

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

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值