這篇文章為大家帶來了關於linux進程間通訊的相關知識,其中包括管道、匿名管道、共享記憶體等相關問題,希望對大家有幫助。
·進程間通訊:#作業系統為系統提供的實作進程間通訊的方式
進程之間是無法直接溝通的,因為每個進程都有獨立的虛擬位址空間,存取的都是自己的虛擬位址,因此進程具有獨立性,無法直接通訊
根據通訊場景的不同,因此提供了多種不同的通訊方式
進程間通訊方式種類:管道、共享記憶體、訊息佇列、訊號量
##·管道
特性:半雙工通訊--可以選擇方向的單向通訊 本質:在核心中開啟一塊緩衝區(核心空間中的一塊記憶體) 原理:多個進程透過存取同一塊核心中的緩衝區實現通訊(複製緩衝區的操作句柄) 分類:匿名管道:緩衝區沒有標識符,只能用於具有親緣關係的進程間通訊 命名管道:緩衝區具有標識符,可用於同一主機上任意的進程間通訊 linux下一切皆檔案--所有東西都是當做檔案同樣進行操作(包括管道),透過IO操作完成對管道的存取·匿名管道
讀寫特性:若管道中沒有數據,read會阻塞
若管道中數據滿了,write會阻塞
所有的管道的讀端關閉,則繼續write則會觸發異常,導致進程崩潰退出
所有的管道的寫端被關閉,則繼續read則會讀取完資料後回傳0,不再阻塞
註:管道是半雙工通信,在通訊時,一旦選定了 方向,應將不使用的那一端關閉。
·
命名管道:#本質是核心中的一塊緩衝區,具有標識符,可以被其他進程找到,因此可用於同一主機上的任意進程間通訊
命名管道的識別碼就是一個可見於檔案系統的管道類型檔案 多個進程透過開啟同一個管道文件,存取同一塊核心中的緩衝區實現通訊 指令操作:mkfifo filename 建立一個命名管道檔案 函數操作:int mkfifo(const char *pathname, mode_t mode) ; pathname:檔案名稱;mode:建立權限 回傳值:成功回傳0;失敗回傳-1##‧總結:
#‧總結:管道的本質:核心空間中的一塊緩衝區 原理:多個進程透過存取同一塊緩衝區來實現資料傳輸 分類:匿名管道、命名管道 ## #### 匿名管道:僅用於具有親緣關係的進程間通訊###### 命名管道:可用於同一主機上任意進程間通訊## --可選擇方向的單向通訊###### 提供位元組串流服務:有序的、可靠的、基於連接的一種串流###### 以連線為基礎:所有讀取端關閉則write異常;所有寫端關閉則read返回0###### ②自帶同步與互斥:###### 同步:透過相同時間進程對臨界資源的唯一存取實現存取安全作業代碼####################################################################################################################################################################################################################' #### 互斥:透過一些條件判斷讓進程對臨界資源的存取更合理有序###互斥的體現:對管道進行寫入操作的大小不超過PIPE_BUF-4096大小,則保證操作的原子性
則write阻塞
③生命週期隨進程:不人為幹預情況下,所有開啟管道的進程退出後,管道緩衝區被釋放
·共享記憶體: 用於實現進程間的資料共享
本質:一塊實體記憶體
原理:開啟一塊實體記憶體空間,多個行程將同一塊對應到自己的虛擬位址空間,透過虛擬位址直接進行訪問,進而實現資料共享
功能:最快的進程間通訊方式,生命週期隨核心
共享記憶體透過虛擬位址直接存取實體內存,實現資料共享,相對於其他方式需要將數據拷貝到內核,使用時拷貝到用戶態,少了兩次資料拷貝操作
注意事項:對共享記憶體的操作需要注意安全性問題
作業流程:
①建立或開啟共享記憶體
②將共享記憶體映射到進程的虛擬位址空間
③透過已對應的虛擬位址進行各種記憶體運算
④ 關聯對應關係式關聯式原則
##int shmget(key_t key, size_t size, int shmflg);
key:識別碼(多個行程透過相同的記憶體識別碼開啟同一塊共享記憶體識別碼size:建立時開啟的空間大小(以記憶體頁為單位)
shmflg:開啟方式 建立權限--IPC_CREAT|IPC_EXCL|0664 --操作句柄;失敗回傳-1void *shmat(int shmid, const void *shmaddr, int shmflg);
## shmid:shmget回傳的操作句柄
o# shmflg:映射成功後的存取方式;SHM_RDONLY-唯讀;0-讀寫
返回值:成功回傳後的首地址返回表示int shmdt(const void *shmaddr);
shmaddr);shmaddr:對應後的首位址 # 回傳值:
0; #int shmctl(int shmid, int cmd, struct shmid_ds *buf);
shmid:shmget回傳的操作句柄## 為被銷毀 buf:對於IPC_RMID,成功回傳0,失敗發送回-1
·訊息佇列
##·訊息佇列
#·訊息佇列
#本質:核心中的一個優先權佇列,多個行程透過存取同一個佇列,為佇列中新增或取得節點而實現行程間的資料區塊傳輸
特性:自帶同步與互斥,生命週期隨核心
#########·信號量############ 本質:核心中的一個計數器pcb等待佇列##### 作用:用於實現進程間的同步與互斥,協調進程對臨界資源的存取###### P操作:計數器-1,判斷若計數小於0則阻塞進程###### V操作:計數器1,喚醒一個阻塞的進程###### 透過自身的計數器對資源進行計數,透過計數判斷進程對資源的取得是否合理,不合理則阻塞。等待產生一個資源之後,喚醒阻塞的程序###### 同步的實現:透過計數器對資源進行計數,在獲取資源之前進行P操作###### 互斥的實現:計數器為1,表示資源只有一個,在進程存取資源之前進行P操作,存取完畢後進行V操作###相關推薦:《Linux影片教學》
以上是經典技巧之Linux進程間通信的詳細內容。更多資訊請關注PHP中文網其他相關文章!

linux设备节点是应用程序和设备驱动程序沟通的一个桥梁;设备节点被创建在“/dev”,是连接内核与用户层的枢纽,相当于硬盘的inode一样的东西,记录了硬件设备的位置和信息。设备节点使用户可以与内核进行硬件的沟通,读写设备以及其他的操作。

区别:1、open是UNIX系统调用函数,而fopen是ANSIC标准中的C语言库函数;2、open的移植性没fopen好;3、fopen只能操纵普通正规文件,而open可以操作普通文件、网络套接字等;4、open无缓冲,fopen有缓冲。

端口映射又称端口转发,是指将外部主机的IP地址的端口映射到Intranet中的一台计算机,当用户访问外网IP的这个端口时,服务器自动将请求映射到对应局域网内部的机器上;可以通过使用动态或固定的公共网络IP路由ADSL宽带路由器来实现。

在linux中,eof是自定义终止符,是“END Of File”的缩写;因为是自定义的终止符,所以eof就不是固定的,可以随意的设置别名,linux中按“ctrl+d”就代表eof,eof一般会配合cat命令用于多行文本输出,指文件末尾。

在linux中,交叉编译是指在一个平台上生成另一个平台上的可执行代码,即编译源代码的平台和执行源代码编译后程序的平台是两个不同的平台。使用交叉编译的原因:1、目标系统没有能力在其上进行本地编译;2、有能力进行源代码编译的平台与目标平台不同。

在linux中,可以利用“rpm -qa pcre”命令判断pcre是否安装;rpm命令专门用于管理各项套件,使用该命令后,若结果中出现pcre的版本信息,则表示pcre已经安装,若没有出现版本信息,则表示没有安装pcre。

linux查询mac地址的方法:1、打开系统,在桌面中点击鼠标右键,选择“打开终端”;2、在终端中,执行“ifconfig”命令,查看输出结果,在输出信息第四行中紧跟“ether”单词后的字符串就是mac地址。

在linux中,rpc是远程过程调用的意思,是Reomote Procedure Call的缩写,特指一种隐藏了过程调用时实际通信细节的IPC方法;linux中通过RPC可以充分利用非共享内存的多处理器环境,提高系统资源的利用率。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3漢化版
中文版,非常好用

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境