Linux下进程间通信的六种机制详解
生活随笔
收集整理的這篇文章主要介紹了
Linux下进程间通信的六种机制详解
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
linux下進(jìn)程間通信的幾種主要手段: ? ?
? ?1.管道(Pipe)及有名管道(named pipe):管道可用于具有親緣關(guān)系進(jìn)程間的通信,有名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關(guān)系進(jìn)程間的通信; ? ?
? ?2.信號(Signal):信號是比較復(fù)雜的通信方式,用于通知接受進(jìn)程有某種事件生,除了用于進(jìn)程間通信外,進(jìn)程還可以發(fā)送信號給進(jìn)程本身;linux除了支持Unix早期 信號語義函數(shù)sigal外,還支持語義符合Posix.1標(biāo)準(zhǔn)的信號函數(shù)sigaction(實際上, 該函數(shù)是基于BSD的,BSD為了實現(xiàn)可靠信號機制,又能夠統(tǒng)一對外接口,sigaction函數(shù)重新實現(xiàn)了signal函數(shù)); ? ?
? ?3.報文(Message)隊列(消息隊列):消息隊列是消息的鏈接表,包括Posix消息隊列system V消息隊列。有足夠權(quán)限的進(jìn)程可以向隊列中添加消息,被賦予讀權(quán)限的進(jìn)程則可以讀走隊列中的消息。消息隊列克服了信號承載信息量少,管道只能承載無格式字節(jié)流以及緩沖區(qū)大小受限等缺點。
? ?4.共享內(nèi)存:使得多個進(jìn)程可以訪問同一塊內(nèi)存空間,是最快的可用IPC形式。是針其他通信機制運行效率較低設(shè)計的。往往與其它通信機制,如信號量結(jié)合使用, 來達(dá)到進(jìn)程間的同步及互斥。 ??
? ?5.信號量(semaphore):主要作為進(jìn)程間以及同一進(jìn)程不同線程之間的同步手段。 ? ? ? ? ? ??
? ?6.套接字(Socket):更為一般的進(jìn)程間通信機制,可用于不同機器之間的進(jìn)程間通信。起初是由Unix系統(tǒng)的BSD分支開發(fā)出來的,但現(xiàn)在一般可以移植到其它類Unix 系統(tǒng)上:Linux和System V的變種都支持套接字。
? ?1.管道(Pipe)及有名管道(named pipe):管道可用于具有親緣關(guān)系進(jìn)程間的通信,有名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關(guān)系進(jìn)程間的通信; ? ?
? ?2.信號(Signal):信號是比較復(fù)雜的通信方式,用于通知接受進(jìn)程有某種事件生,除了用于進(jìn)程間通信外,進(jìn)程還可以發(fā)送信號給進(jìn)程本身;linux除了支持Unix早期 信號語義函數(shù)sigal外,還支持語義符合Posix.1標(biāo)準(zhǔn)的信號函數(shù)sigaction(實際上, 該函數(shù)是基于BSD的,BSD為了實現(xiàn)可靠信號機制,又能夠統(tǒng)一對外接口,sigaction函數(shù)重新實現(xiàn)了signal函數(shù)); ? ?
? ?3.報文(Message)隊列(消息隊列):消息隊列是消息的鏈接表,包括Posix消息隊列system V消息隊列。有足夠權(quán)限的進(jìn)程可以向隊列中添加消息,被賦予讀權(quán)限的進(jìn)程則可以讀走隊列中的消息。消息隊列克服了信號承載信息量少,管道只能承載無格式字節(jié)流以及緩沖區(qū)大小受限等缺點。
? ?4.共享內(nèi)存:使得多個進(jìn)程可以訪問同一塊內(nèi)存空間,是最快的可用IPC形式。是針其他通信機制運行效率較低設(shè)計的。往往與其它通信機制,如信號量結(jié)合使用, 來達(dá)到進(jìn)程間的同步及互斥。 ??
? ?5.信號量(semaphore):主要作為進(jìn)程間以及同一進(jìn)程不同線程之間的同步手段。 ? ? ? ? ? ??
? ?6.套接字(Socket):更為一般的進(jìn)程間通信機制,可用于不同機器之間的進(jìn)程間通信。起初是由Unix系統(tǒng)的BSD分支開發(fā)出來的,但現(xiàn)在一般可以移植到其它類Unix 系統(tǒng)上:Linux和System V的變種都支持套接字。
總結(jié)
以上是生活随笔為你收集整理的Linux下进程间通信的六种机制详解的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 承载千万级并发的分布式系统架构设计思想
- 下一篇: 静态链接库、动态链接库和动态加载库