linux 共享内存陷井,linux共享内存应用与陷阱
共享內存是系統出于多個進程之間通訊的考慮,而預留的的一塊內存區。在/proc/sys/kernel/目錄下,記錄著共享內存的一些限制,如一個共享內存區的最大字節數shmmax,系統范圍內最大共享內存區標識符數shmmni等,可以手工對其調整,但不推薦這樣做。
一、應用
共享內存的使用,主要有以下幾個API:ftok()、shmget()、shmat()、shmdt()及shmctl()。
1)用ftok()函數獲得一個ID號.
應用說明:
在IPC中,我們經常用用key_t的值來創建或者打開信號量,共享內存和消息隊列。
函數原型:
key_t ftok(const char *pathname, int proj_id);
Keys:
1)pathname一定要在系統中存在并且進程能夠訪問的
3)proj_id是一個1-255之間的一個整數值,典型的值是一個ASCII值。
當成功執行的時候,一個key_t值將會被返回,否則-1被返回。我們可以使用strerror(errno)來確定具體的錯誤信息。
考慮到應用系統可能在不同的主機上應用,可以直接定義一個key,而不用ftok獲得:
#define IPCKEY 0x344378
2)shmget()用來開辟/指向一塊共享內存的函數
應用說明:
shmget()用來獲得共享內存區域的ID,如果不存在指定的共享區域就創建相應的區域。
函數原型:
int shmget(key_t key, size_t size, int shmflg);
key_t key 是這塊共享內存的標識符。如果是父子關系的進程間通信的話,這個標識符用IPC_PRIVATE來代替。如果兩個進程沒有任何關系,所以就用ftok()算出來一個標識符(或者自己定義一個)使用了。
int size 是這塊內存的大小.
int flag 是這塊內存的模式(mode)以及權限標識。
模式可取如下值:
IPC_CREAT 新建(如果已創建則返回目前共享內存的id)
IPC_EXCL 與IPC_CREAT結合使用,如果已創建則則返回錯誤
然后將“模式” 和“權限標識”進行“或”運算,做為第三個參數。
如: IPC_CREAT | IPC_EXCL | 0640
例子中的0666為權限標識,4/2/1 分別表示讀/寫/執行3種權限,第一個0是UID,第一個6(4+2)表示擁有者的權限,第二個4表示同組權限,第3個0表示他人的權限。
這個函數成功時返回共享內存的ID,失敗時返回-1。
關于這個函數,要多說兩句。
創建共享內存時,shmflg參數至少需要 IPC_CREAT | 權限標識,如果只有IPC_CREAT 則申請的地址都是k=0xffffffff,不能使用;
獲取已創建的共享內存時,shmflg不要用IPC_CREAT(只能用創建共享內存時的權限
標識,如0640),否則在某些情況下,比如用ipcrm刪除共享內存后,用該函數并用IPC_CREAT參數獲取一次共享內存(當然,獲取失敗),則即使再次創建共享內存也不能成功,此時必須更改key來重建共享內存。
3) shmat()將這個內存區映射到本進程的虛擬地址空間。
函數
總結
以上是生活随笔為你收集整理的linux 共享内存陷井,linux共享内存应用与陷阱的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 为何英国盛产上好的威士忌?
- 下一篇: linux .vimrc教程,vim配置