在用于串行通信的多线程Linux程序中,是否有可能(以及最好的方法)终止来自另一个线程的阻塞read()调用?
我希望尽可能保持一切反应,并避免在重复轮询时使用超时.
这个问题的背景是我正在尝试使用JNI为Linux创建一个Scala串行通信库.我试图保持原生方尽可能简单,除其他外,提供read()和close()函数.在Scala端,一个线程将调用read()并阻塞,直到来自串行端口的数据可用.但是,串口可以通过其他方式关闭,从而调用close().现在,为了释放被阻止的线程,我会以某种方式取消系统读取调用.
最佳答案
一个相当流行的技巧:不是在read()中阻塞,而是在串行套接字和管道上的select()中阻塞.然后当另一个线程想要唤醒你的线程时,它可以通过将一个字节写入该管道的另一端来实现.该字节将导致select()返回,您的线程现在可以清理并退出或无论需要做什么. (注意,为了使这项工作100%可靠,您可能希望将串行套接字设置为非阻塞,以确保您的线程仅在select()中阻塞而从不在read()中阻塞
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。