資料介紹
8.5.1 共享內(nèi)存概述
可以說,共享內(nèi)存是一種最為高效的進程間通信方式。因為進程可以直接讀寫內(nèi)存,不需要任何數(shù)據(jù)的復制。為了在多個進程間交換信息,內(nèi)核專門留出了一塊內(nèi)存區(qū)。這段內(nèi)存區(qū)可以由需要訪問的進程將其映射到自己的私有地址空間。因此,進程就可以直接讀寫這一內(nèi)存區(qū)而不需要進行數(shù)據(jù)的復制,從而大大提高了效率。當然,由于多個進程共享一段內(nèi)存,因此也需要依靠某種同步機制,如互斥鎖和信號量等(請參考本章的共享內(nèi)存實驗)。其原理示意圖如圖8.8所示。
![進程間通信之共享內(nèi)存](/uploads/allimg/171018/2362486-1G01Q60954a0.png)
圖8.8 共享內(nèi)存原理示意圖
8.5.2 共享內(nèi)存的應用
1.函數(shù)說明
共享內(nèi)存的實現(xiàn)分為兩個步驟,第一步是創(chuàng)建共享內(nèi)存,這里用到的函數(shù)是shmget(),也就是從內(nèi)存中獲得一段共享內(nèi)存區(qū)域,第二步映射共享內(nèi)存,也就是把這段創(chuàng)建的共享內(nèi)存映射到具體的進程空間中,這里使用的函數(shù)是shmat()。到這里,就可以使用這段共享內(nèi)存了,也就是可以使用不帶緩沖的I/O讀寫命令對其進行操作。除此之外,當然還有撤銷映射的操作,其函數(shù)為shmdt()。這里就主要介紹這3個函數(shù)。
2.函數(shù)格式
表8.20列舉了shmget()函數(shù)的語法要點。
表8.20 shmget()函數(shù)語法要點
所需頭文件#include 《sys/types.h》
#include 《sys/ipc.h》
#include 《sys/shm.h》
函數(shù)原型int shmget(key_t key, int size, int shmflg)
函數(shù)傳入值key:共享內(nèi)存的鍵值,多個進程可以通過它訪問同一個共享內(nèi)存,其中有個特殊值IPC_PRIVATE。它用于創(chuàng)建當前進程的私有共享內(nèi)存
size:共享內(nèi)存區(qū)大小
shmflg:同open()函數(shù)的權限位,也可以用八進制表示法
函數(shù)返回值成功:共享內(nèi)存段標識符
出錯:-1
表8.21列舉了shmat()函數(shù)的語法要點。
表8.21 shmat()函數(shù)語法要點
所需頭文件#include 《sys/types.h》
#include 《sys/ipc.h》
#include 《sys/shm.h》
函數(shù)原型char *shmat(int shmid, const void *shmaddr, int shmflg)
函數(shù)傳入值shmid:要映射的共享內(nèi)存區(qū)標識符
shmaddr:將共享內(nèi)存映射到指定地址(若為0則表示系統(tǒng)自動分配地址并把該段共享內(nèi)存映射到調(diào)用進程的地址空間)
shmflg SHM_RDONLY:共享內(nèi)存只讀
默認0:共享內(nèi)存可讀寫
函數(shù)返回值成功:被映射的段地址
出錯:-1
表8.22列舉了shmdt()函數(shù)的語法要點。
表8.22 shmdt()函數(shù)語法要點
所需頭文件#include 《sys/types.h》
#include 《sys/ipc.h》
#include 《sys/shm.h》
函數(shù)原型int shmdt(const void *shmaddr)
函數(shù)傳入值shmaddr:被映射的共享內(nèi)存段地址
函數(shù)返回值成功:0
出錯:-1
3.使用實例
該實例說明如何使用基本的共享內(nèi)存函數(shù)。首先是創(chuàng)建一個共享內(nèi)存區(qū)(采用的共享內(nèi)存的鍵值為IPC_PRIVATE,是因為本實例中創(chuàng)建的共享內(nèi)存是父子進程之間的共用部分),之后創(chuàng)建子進程,在父子兩個進程中將共享內(nèi)存分別映射到各自的進程地址空間之中。
父進程先等待用戶輸入,然后將用戶輸入的字符串寫入到共享內(nèi)存,之后往共享內(nèi)存的頭部寫入“WROTE”字符串表示父進程已成功寫入數(shù)據(jù)。子進程一直等到共享內(nèi)存的頭部字符串為“WROTE”,然后將共享內(nèi)存的有效數(shù)據(jù)(在父進程中用戶輸入的字符串)在屏幕上打印。父子兩個進程在完成以上工作之后,分別解除與共享內(nèi)存的映射關系。
最后在子進程中刪除共享內(nèi)存。因為共享內(nèi)存自身并不提供同步機制,所以應該額外實現(xiàn)不同進程之間的同步(例如:信號量)。為了簡單起見,在本實例中用標志字符串來實現(xiàn)非常簡單的父子進程之間的同步。
可以說,共享內(nèi)存是一種最為高效的進程間通信方式。因為進程可以直接讀寫內(nèi)存,不需要任何數(shù)據(jù)的復制。為了在多個進程間交換信息,內(nèi)核專門留出了一塊內(nèi)存區(qū)。這段內(nèi)存區(qū)可以由需要訪問的進程將其映射到自己的私有地址空間。因此,進程就可以直接讀寫這一內(nèi)存區(qū)而不需要進行數(shù)據(jù)的復制,從而大大提高了效率。當然,由于多個進程共享一段內(nèi)存,因此也需要依靠某種同步機制,如互斥鎖和信號量等(請參考本章的共享內(nèi)存實驗)。其原理示意圖如圖8.8所示。
![進程間通信之共享內(nèi)存](/uploads/allimg/171018/2362486-1G01Q60954a0.png)
圖8.8 共享內(nèi)存原理示意圖
8.5.2 共享內(nèi)存的應用
1.函數(shù)說明
共享內(nèi)存的實現(xiàn)分為兩個步驟,第一步是創(chuàng)建共享內(nèi)存,這里用到的函數(shù)是shmget(),也就是從內(nèi)存中獲得一段共享內(nèi)存區(qū)域,第二步映射共享內(nèi)存,也就是把這段創(chuàng)建的共享內(nèi)存映射到具體的進程空間中,這里使用的函數(shù)是shmat()。到這里,就可以使用這段共享內(nèi)存了,也就是可以使用不帶緩沖的I/O讀寫命令對其進行操作。除此之外,當然還有撤銷映射的操作,其函數(shù)為shmdt()。這里就主要介紹這3個函數(shù)。
2.函數(shù)格式
表8.20列舉了shmget()函數(shù)的語法要點。
表8.20 shmget()函數(shù)語法要點
所需頭文件#include 《sys/types.h》
#include 《sys/ipc.h》
#include 《sys/shm.h》
函數(shù)原型int shmget(key_t key, int size, int shmflg)
函數(shù)傳入值key:共享內(nèi)存的鍵值,多個進程可以通過它訪問同一個共享內(nèi)存,其中有個特殊值IPC_PRIVATE。它用于創(chuàng)建當前進程的私有共享內(nèi)存
size:共享內(nèi)存區(qū)大小
shmflg:同open()函數(shù)的權限位,也可以用八進制表示法
函數(shù)返回值成功:共享內(nèi)存段標識符
出錯:-1
表8.21列舉了shmat()函數(shù)的語法要點。
表8.21 shmat()函數(shù)語法要點
所需頭文件#include 《sys/types.h》
#include 《sys/ipc.h》
#include 《sys/shm.h》
函數(shù)原型char *shmat(int shmid, const void *shmaddr, int shmflg)
函數(shù)傳入值shmid:要映射的共享內(nèi)存區(qū)標識符
shmaddr:將共享內(nèi)存映射到指定地址(若為0則表示系統(tǒng)自動分配地址并把該段共享內(nèi)存映射到調(diào)用進程的地址空間)
shmflg SHM_RDONLY:共享內(nèi)存只讀
默認0:共享內(nèi)存可讀寫
函數(shù)返回值成功:被映射的段地址
出錯:-1
表8.22列舉了shmdt()函數(shù)的語法要點。
表8.22 shmdt()函數(shù)語法要點
所需頭文件#include 《sys/types.h》
#include 《sys/ipc.h》
#include 《sys/shm.h》
函數(shù)原型int shmdt(const void *shmaddr)
函數(shù)傳入值shmaddr:被映射的共享內(nèi)存段地址
函數(shù)返回值成功:0
出錯:-1
3.使用實例
該實例說明如何使用基本的共享內(nèi)存函數(shù)。首先是創(chuàng)建一個共享內(nèi)存區(qū)(采用的共享內(nèi)存的鍵值為IPC_PRIVATE,是因為本實例中創(chuàng)建的共享內(nèi)存是父子進程之間的共用部分),之后創(chuàng)建子進程,在父子兩個進程中將共享內(nèi)存分別映射到各自的進程地址空間之中。
父進程先等待用戶輸入,然后將用戶輸入的字符串寫入到共享內(nèi)存,之后往共享內(nèi)存的頭部寫入“WROTE”字符串表示父進程已成功寫入數(shù)據(jù)。子進程一直等到共享內(nèi)存的頭部字符串為“WROTE”,然后將共享內(nèi)存的有效數(shù)據(jù)(在父進程中用戶輸入的字符串)在屏幕上打印。父子兩個進程在完成以上工作之后,分別解除與共享內(nèi)存的映射關系。
最后在子進程中刪除共享內(nèi)存。因為共享內(nèi)存自身并不提供同步機制,所以應該額外實現(xiàn)不同進程之間的同步(例如:信號量)。為了簡單起見,在本實例中用標志字符串來實現(xiàn)非常簡單的父子進程之間的同步。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 談談嵌入式系統(tǒng)中多進程設計與進程通信
- 嵌入式Linux進程 -進程間通信
- Glibc內(nèi)存管理之Ptmalloc2源代碼分析 24次下載
- 串口通信之讀取與發(fā)送及LabView文件下載 184次下載
- 鴻蒙內(nèi)核源碼分析:進程是內(nèi)核的資源管理單元 23次下載
- TD-SCDMA無線通信技術的演變進程與其他技術比較和系統(tǒng)結構介紹 21次下載
- 如何設置代碼編寫器Studio集成開發(fā)環(huán)境(IDE)來調(diào)試共享內(nèi)存系統(tǒng) 1次下載
- 共享內(nèi)存的無人車進程消息異步傳輸 0次下載
- linux操作系統(tǒng)下的進程通信 0次下載
- 進程間通信之Linux下進程間通信概述 0次下載
- 進程間通信之使用信號詳解 0次下載
- 進程間通信之信號量淺析 0次下載
- 進程間通信之:管道 0次下載
- μClinux內(nèi)存管理分析
- 理解并使用共享內(nèi)存
- 內(nèi)存共享原理解析 1351次閱讀
- 線程是什么的基本單位 進程與線程的本質(zhì)區(qū)別 980次閱讀
- EC SRAM映射到CPU Memory空間的共享內(nèi)存設計 1741次閱讀
- 使用Rust語言的WinAPI模塊來實現(xiàn)共享內(nèi)存 2082次閱讀
- 程序中進程和線程的區(qū)別 696次閱讀
- Linux應用開發(fā)之共享內(nèi)存 449次閱讀
- 虛擬內(nèi)存的那點事兒 767次閱讀
- 進程間通信的實現(xiàn)方式 771次閱讀
- Linux進程間通信方法之管道 1997次閱讀
- Linux進程的內(nèi)存消耗和泄漏詳解 2709次閱讀
- Linux:測試進程占用的虛擬內(nèi)存大小 2904次閱讀
- 虛擬機:查看進程內(nèi)存和CPU占用的方法 8538次閱讀
- 共享內(nèi)存IPC原理,Linux進程間如何共享內(nèi)存? 8656次閱讀
- 基于linux的進程通信設計方案 533次閱讀
- 進程間與線程間的通信方式 8945次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論