C++共享內(nèi)存刪除的陷阱
文章轉(zhuǎn)自微信公眾號:CPP開發(fā)前沿
當(dāng)進(jìn)程結(jié)束使用共享內(nèi)存區(qū)時,要通過函數(shù) shmdt
斷開與共享內(nèi)存區(qū)的連接。該函數(shù)聲明在 sys/shm.h 中,其原型如下:
int shmdt(const void *shmaddr);
參數(shù) shmaddr 是 shmat 函數(shù)的返回值。
進(jìn)程脫離共享內(nèi)存區(qū)后,數(shù)據(jù)結(jié)構(gòu) shmid_ds
中的 shm_nattch
就會減 1 。但是共享段內(nèi)存依然存在,只有 shm_attch
為 0 后,即沒有任何進(jìn)程再使用該共享內(nèi)存區(qū),共享內(nèi)存區(qū)才在內(nèi)核中被刪除。一般來說,當(dāng)一個進(jìn)程終止時,它所附加的共享內(nèi)存區(qū)都會自動脫離。
我們通過:
int shmctl( int shmid , int cmd , struct shmid_ds *buf );
來刪除已經(jīng)存在的共享內(nèi)存:
- 第一個參數(shù),
shmid
,是由shmget所返回的標(biāo)記符。 - 第二個參數(shù),
cmd
,是要執(zhí)行的動作。他可以有三個值:
命令 描述:
IPC_STAT
設(shè)置shmid_ds
結(jié)構(gòu)中的數(shù)據(jù)反射與共享內(nèi)存相關(guān)聯(lián)的值。IPC_SET
如果進(jìn)程有相應(yīng)的權(quán)限,將與共享內(nèi)存相關(guān)聯(lián)的值設(shè)置為shmid_ds
數(shù)據(jù)結(jié)構(gòu)中所提供的值。IPC_RMID
刪除共享內(nèi)存段。- 第三個參數(shù),buf,是一個指向包含共享內(nèi)存模式與權(quán)限的結(jié)構(gòu)的指針,刪除的時候可以默認(rèn)為0。
如果共享內(nèi)存已經(jīng)與所有訪問它的進(jìn)程斷開了連接,則調(diào)用IPC_RMID子命令后,系統(tǒng)將立即刪除共享內(nèi)存的標(biāo)識符,并刪除該共享內(nèi)存區(qū),以及所有相關(guān)的數(shù)據(jù)結(jié)構(gòu);
如果仍有別的進(jìn)程與該共享內(nèi)存保持連接,則調(diào)用IPC_RMID子命令后,該共享內(nèi)存并不會被立即從系統(tǒng)中刪除,而是被設(shè)置為IPC_PRIVATE狀態(tài),并被標(biāo)記為”已被刪除”(使用ipcs命令可以看到dest字段);直到已有連接全部斷開,該共享內(nèi)存才會最終從系統(tǒng)中消失。
需要說明的是:一旦通過shmctl對共享內(nèi)存進(jìn)行了刪除操作,則該共享內(nèi)存將不能再接受任何新的連接,即使它依然存在于系統(tǒng)中!所以,可以確知, 在對共享內(nèi)存刪除之后不可能再有新的連接,則執(zhí)行刪除操作是安全的;否則,在刪除操作之后如仍有新的連接發(fā)生,則這些連接都將可能失??!
Shmdt和shmctl的區(qū)別:
hmdt
是將共享內(nèi)存從進(jìn)程空間detach
出來,使進(jìn)程中的shmid
無效化,不可以使用。但是保留空間。
而shmctl
(sid,IPC_RMID,0)則是刪除共享內(nèi)存,徹底不可用,釋放空間。
到此這篇關(guān)于C++共享內(nèi)存刪除的陷阱的文章就介紹到這了,更多相關(guān)共享內(nèi)存刪除的陷阱內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實(shí)現(xiàn)員工工資管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)員工工資管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02C++實(shí)現(xiàn)紅黑樹核心插入實(shí)例代碼
紅黑樹是一種二叉搜索樹,但在每個結(jié)點(diǎn)上增加一個存儲位表示結(jié)點(diǎn)的顏色,可以是Red或Black,下面這篇文章主要給大家介紹了關(guān)于C++實(shí)現(xiàn)紅黑樹核心插入的相關(guān)資料,需要的朋友可以參考下2023-06-06C語言數(shù)據(jù)結(jié)構(gòu)系列篇二叉樹的概念及滿二叉樹與完全二叉樹
在上一章中我們正式開啟了對數(shù)據(jù)結(jié)構(gòu)中樹的講解,介紹了樹的基礎(chǔ)。本章我們將學(xué)習(xí)二叉樹的概念,介紹滿二叉樹和完全二叉樹的定義,并對二叉樹的基本性質(zhì)進(jìn)行一個簡單的介紹。本章附帶課后練習(xí)2022-02-02