Linux 執行緒間通訊方式 程序通訊方式

2021-10-03 09:51:00 字數 1479 閱讀 8699

1. linux下程序間通訊的幾種主要手段簡介:

管道(pipe)及有名管道(named pipe):管道可用於具有親緣關係程序間的通訊,有名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關係程序間的通訊;

訊號(signal):訊號是比較複雜的通訊方式,用於通知接受程序有某種事件發生,除了用於程序間通訊外,程序還可以傳送訊號給程序本身;linux除了支援unix早期訊號語義函式sigal外,還支援語義符合posix.1標準的訊號函式sigaction(實際上,該函式是基於bsd的,bsd為了實現可靠訊號機制,又能夠統一對外介面,用sigaction函式重新實現了signal函式);

報文(message)佇列(訊息佇列):訊息佇列是訊息的鏈結表,包括posix訊息佇列system v訊息佇列。有足夠許可權的程序可以向佇列中新增訊息,被賦予讀許可權的程序則可以讀走佇列中的訊息。訊息佇列克服了訊號承載資訊量少,管道只能承載無格式位元組流以及緩衝區大小受限等缺點。

共享記憶體:使得多個程序可以訪問同一塊記憶體空間,是最快的可用ipc形式。是針對其他通訊機制執行效率較低而設計的。往往與其它通訊機制,如訊號量結合使用,來達到程序間的同步及互斥。

訊號量(semaphore):主要作為程序間以及同一程序不同執行緒之間的同步手段。

套介面(socket):更為一般的程序間通訊機制,可用於不同機器之間的程序間通訊。起初是由unix系統的bsd分支開發出來的,但現在一般可以移植到其它類unix系統上:linux和system v的變種都支援套接字。

一般來說,linux下的程序包含以下幾個關鍵要素:

執行緒間的通訊目的主要是用於執行緒同步,所以執行緒沒有像程序通訊中的用於資料交換的通訊機制。

2. linux系統中的執行緒間通訊方式主要以下幾種:

*鎖機制:包括互斥鎖、條件變數、讀寫鎖和自旋鎖。

互斥鎖確保同一時間只能有乙個執行緒訪問共享資源。當鎖被占用時試圖對其加鎖的執行緒都進入阻塞狀態(釋放cpu資源使其由執行狀態進入等待狀態)。當鎖釋放時哪個等待執行緒能獲得該鎖取決於核心的排程。

讀寫鎖當以寫模式加鎖而處於寫狀態時任何試圖加鎖的執行緒(不論是讀或寫)都阻塞,當以讀狀態模式加鎖而處於讀狀態時「讀」執行緒不阻塞,「寫」執行緒阻塞。讀模式共享,寫模式互斥。

條件變數可以以原子的方式阻塞程序,直到某個特定條件為真為止。對條件的測試是在互斥鎖的保護下進行的。條件變數始終與互斥鎖一起使用。

*訊號量機制(semaphore):包括無名執行緒訊號量和命名執行緒訊號量

*訊號機制(signal):類似程序間的訊號處理

程序間通訊方式和執行緒間通訊方式

1.管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。2.訊號量 semophore 訊號量是乙個計數器,可以用來控制多個程序對共享資源的訪問。它常作為一種鎖機制,防止某程序正在訪問共享資源時,其他程序也訪問該資源。...

程序間通訊方式和執行緒間通訊方式

1.管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。缺點 速度慢,容量有限,只有父子程序能通訊 2.有名管道 namedpipe 有名管道也是半雙工的通訊方式,但是它允許無親緣關係程序間的通訊。但速度慢。3.訊號量...

程序間的通訊方式,執行緒間的通訊方式 程序

當時做筆記的時候 忘了在 看到的了,有時間我再研究研究 管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。有名管道 namedpipe 有名管道也是半雙工的通訊方式,但是它允許無親緣關係程序間的通訊。訊號量 semo...