解决UNIX编程中的阻塞问题:进程、线程与统一事件管理器
1. 阻塞问题概述
在UNIX编程里,我们常常会碰到一些会导致程序阻塞的系统调用,像 read 、 write 、 pthread_cond_wait 和 waitpid 等。由于无法预知后续会发生什么,应用程序可能需要在多个系统调用中进行阻塞,这就是所谓的阻塞问题。
对于像 read 和 write 这类需要文件描述符的阻塞系统调用,我们可以使用 select 或 poll 这两个系统调用,让程序阻塞直至一个或多个文件描述符准备就绪。然而,很多我们需要等待的事件,比如进程、信号、消息、信号量和条件变量等,都与文件描述符没有关联。即便我们可以通过向专门设置的管道写入数据,来通知阻塞在 select 或 poll 中的线程有消息到达,但这并不能解决 msgrcv 或 mq_receive 本身因等待消息而阻塞的问题。因为没办法直接将等待消息的系统调用与文件描述符关联起来,所以这本质上是一个阻塞问题,而非通知问题。
2. 使用进程和线程解决阻塞问题
- 使用进程的解决方案 :以往,解决阻塞问题的办法是创建一个子进程进行阻塞操作。当子进程所等待的事件解除阻塞后,它会向管道写入数据,以此告知父进程事件已经发
超级会员免费看
订阅专栏 解锁全文
746

被折叠的 条评论
为什么被折叠?



