[Linux] 进程间通信
1.管道(Pipe)及有名管道(namedpipe):管道可用于具有親緣關系進程間的通信,有名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關系進程間的通信
2.信號(Signal):信號是比較復雜的通信方式,用于通知接受進程有某種事件發生,除了用于進程間通信外,進程還可以發送信號給進程本身;linux除了支持Unix早期信號語義函數sigal外,還支持語義符合Posix.1標準的信號函數sigaction(實際上,該函數是基于BSD的,BSD為了實現可靠信號機制,又能夠統一對外接口,用sigaction函數重新實現了signal函數)
3.消息隊列:消息隊列是消息的鏈接表,包括Posix消息隊列systemV消息隊列.有足夠權限的進程可以向隊列中添加消息,被賦予讀權限的進程則可以讀走隊列中的消息.消息隊列克服了信號承載信息量少,管道只能承載無格式字節流以及緩沖區大小受限等缺點.
共享內存:使得多個進程可以訪問同一塊內存空間,是最快的可用IPC形式.是針對其他通信機制運行效率較低而設計的.往往與其它通信機制,如信號量結合使用,來達到進程間的同步及互斥.
4.信號量(semaphore):主要作為進程間以及同一進程不同線程之間的同步手段。
5.套接口(Socket):更為一般的進程間通信機制,可用于不同機器之間的進程間通信.起初是由Unix系統的BSD分支開發出來的,但現在一般可以移植到其它類Unix系統上:Linux和SystemV的變種都支持套接字.
PHP版本實現:https://www.jianshu.com/p/08bcf724196b
?
轉載于:https://www.cnblogs.com/taoshihan/p/11284767.html
總結
以上是生活随笔為你收集整理的[Linux] 进程间通信的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ubuntu 构建 deb 安装包
- 下一篇: 斯坦福大学深度学习与自然语言处理第一讲引