在项目开发时碰到这样一个比较奇怪的问题:应用的某个子线程中调用printf向debug串口输出log,当串口连接到PC的时候,没有问题,一旦串口线与PC串口断开,则在一定时间内,该子线程会阻塞,但只要串口线一连接上PC,阻塞解除。初步估计可能是因为printf导致buffer满了以后阻塞此调用,因为printf输出内容很多时,很快就阻塞,而printf内容较少时,这个时间要长一些。 这里我只是猜测,请教下论坛里的达人,有谁知道原因,谢谢,在线等~~~
------解决方案--------------------
是不是判断有误。
没有串口连接只会造成数据丢失,不会阻塞。
------解决方案--------------------
难不成用了握手信号,握手不成功不发送数据?
但是通常printf只是单纯输出数据
看看底层串口驱动吧,是怎么处理的
------解决方案--------------------
------解决方案--------------------
连上串口后,你的接收程序就能正常工作了。而如果断开串口,就只是发送数据,看一看你的软件是查询式发送还是中断发送数据。另外,你可以用条件编译将printf全部ommit掉,看看断开串口是否阻塞;当然,printf本身还具有延时功能。
------解决方案--------------------
------解决方案--------------------
------解决方案--------------------
估计是驱动的问题,与printf无关
------解决方案--------------------
printf要访问硬件,势必会有全局锁和线程调度