• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開(kāi)心的工作
            簡(jiǎn)單、開(kāi)放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            linux 共享內(nèi)存的使用

            Posted on 2012-01-02 23:36 S.l.e!ep.¢% 閱讀(2280) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Unix

            使用共享內(nèi)存的目的:
            ?共享內(nèi)存共享內(nèi)存是進(jìn)程間通信中最簡(jiǎn)單的方式之一。
            ?共享內(nèi)存允許兩個(gè)或更多進(jìn)程訪問(wèn)同一塊內(nèi)存,就如同 malloc() 函數(shù)向不同進(jìn)程返回了指向同一個(gè)物理內(nèi)存區(qū)域的指針。
            ?當(dāng)一個(gè)進(jìn)程改變了這塊地址中的內(nèi)容的時(shí)候,其它進(jìn)程都會(huì)察覺(jué)到這個(gè)更改。
            使用共享內(nèi)存的流程:
            ?1.進(jìn)程必須首先分配它。
            ?2.隨后需要訪問(wèn)這個(gè)共享內(nèi)存塊的每一個(gè)進(jìn)程都必須將這個(gè)共享內(nèi)存綁定到自己的地址空間中。
            ?3.當(dāng)完成通信之后,所有進(jìn)程都將脫離共享內(nèi)存,并且由一個(gè)進(jìn)程釋放該共享內(nèi)存塊。
            分配:
            ?int segment_id = shmget (shm_key, int size , shmflag );
            ?1.進(jìn)程通過(guò)調(diào)用shmget(Shared Memory GET,獲取共享內(nèi)存)來(lái)分配一個(gè)共享內(nèi)存塊。 該函數(shù)的第一個(gè)參數(shù)是一個(gè)用來(lái)標(biāo)識(shí)共享內(nèi)存塊的鍵值。
            ?彼此無(wú)關(guān)的進(jìn)程可以通過(guò)指定同一個(gè)鍵以獲取對(duì)同一個(gè)共享內(nèi)存塊的訪問(wèn)。
            ?不幸的是,其它程序也可能挑選了同樣的特定值作為自己分配共享內(nèi)存的鍵值,從而產(chǎn)生沖突。
            ?用特殊常量IPC_PRIVATE作為鍵值可以保證系統(tǒng)建立一個(gè)全新的共享內(nèi)存塊。
            ?2.該函數(shù)的第二個(gè)參數(shù)指定了所申請(qǐng)的內(nèi)存塊的大小。
            ?因?yàn)檫@些內(nèi)存塊是以頁(yè)面為單位進(jìn)行分配的,實(shí)際分配的內(nèi)存塊大小將被擴(kuò)大到頁(yè)面大小的整數(shù)倍。
            ?3.第三個(gè)參數(shù)是一組標(biāo)志,通過(guò)特定常量的按位或操作來(lái)shmget。這些特定常量包括:
            ?IPC_CREAT:
            ??這個(gè)標(biāo)志表示應(yīng)創(chuàng)建一個(gè)新的共享內(nèi)存塊。通過(guò)指定這個(gè)標(biāo)志,我們可以創(chuàng)建一個(gè)具有指定鍵值的新共享內(nèi)存塊。
            ?IPC_EXCL:
            ??這個(gè)標(biāo)志只能與 IPC_CREAT 同時(shí)使用。當(dāng)指定這個(gè)標(biāo)志的時(shí)候,如果已有一個(gè)具有這個(gè)鍵值的共享內(nèi)存塊存在,則shmget會(huì)調(diào)用失敗。
            ??也就是說(shuō),這個(gè)標(biāo)志將使線程獲得一個(gè)“獨(dú)有”的共享內(nèi)存塊。如果沒(méi)有指定這個(gè)標(biāo)志而系統(tǒng)中存在一個(gè)具有相通鍵值的共享內(nèi)存塊,
            ??shmget會(huì)返回這個(gè)已經(jīng)建立的共享內(nèi)存塊,而不是重新創(chuàng)建一個(gè)。
            ?模式標(biāo)志:
            ??這個(gè)值由9個(gè)位組成,分別表示屬主、屬組和其它用戶對(duì)該內(nèi)存塊的訪問(wèn)權(quán)限。其中表示執(zhí)行權(quán)限的位將被忽略。
            ??指明訪問(wèn)權(quán)限的一個(gè)簡(jiǎn)單辦法是利用<sys/stat.h>中指定,并且在手冊(cè)頁(yè)第二節(jié)stat條目中說(shuō)明了的常量指定。
            ??例如,
            ???S_IRUSR和S_IWUSR分別指定了該內(nèi)存塊屬主的讀寫(xiě)權(quán)限,
            ???S_IROTH和S_IWOTH則指定了其它用戶的讀寫(xiě)權(quán)限。
            綁定和脫離:
            ?pst= shmat(iShm_id, NULL, 0)
            ?一個(gè)進(jìn)程獲取對(duì)一塊共享內(nèi)存的訪問(wèn),這個(gè)進(jìn)程必須先調(diào)用 shmat(SHared Memory Attach,綁定到共享內(nèi)存)。
            ?將 shmget 返回的共享內(nèi)存標(biāo)識(shí)符 SHMID 傳遞給這個(gè)函數(shù)作為第一個(gè)參數(shù)。
            ?第二個(gè)參數(shù)是一個(gè)指針,指向您希望用于映射該共享內(nèi)存塊的進(jìn)程內(nèi)存地址;如果您指定NULL則Linux會(huì)自動(dòng)選擇一個(gè)合適的地址用于映射。
            ?第三個(gè)參數(shù)是一個(gè)標(biāo)志位,包含了以下選項(xiàng):   
            ??SHM_RND
            ???表示第二個(gè)參數(shù)指定的地址應(yīng)被向下靠攏到內(nèi)存頁(yè)面大小的整數(shù)倍。
            ???如果您不指定這個(gè)標(biāo)志,您將不得不在調(diào)用shmat的時(shí)候手工將共享內(nèi)存塊的大小按頁(yè)面大小對(duì)齊。
            ??SHM_RDONLY
            ???表示這個(gè)內(nèi)存塊將僅允許讀取操作而禁止寫(xiě)入。 如果這個(gè)函數(shù)調(diào)用成功則會(huì)返回綁定的共享內(nèi)存塊對(duì)應(yīng)的地址。
            ???通過(guò) fork 函數(shù)創(chuàng)建的子進(jìn)程同時(shí)繼承這些共享內(nèi)存塊;
            ???如果需要,它們可以主動(dòng)脫離這些共享內(nèi)存塊。
            ???當(dāng)一個(gè)進(jìn)程不再使用一個(gè)共享內(nèi)存塊的時(shí)候應(yīng)通過(guò)調(diào)用 shmdt(Shared Memory Detach,脫離共享內(nèi)存塊)
            ???函數(shù)與該共享內(nèi)存塊脫離。將由 shmat 函數(shù)返回的地址傳遞給這個(gè)函數(shù)。
            ???如果當(dāng)釋放這個(gè)內(nèi)存塊的進(jìn)程是最后一個(gè)使用該內(nèi)存塊的進(jìn)程,則這個(gè)內(nèi)存塊將被刪除。
            ???對(duì) exit 或任何exec族函數(shù)的調(diào)用都會(huì)自動(dòng)使進(jìn)程脫離共享內(nèi)存塊。
            控制和釋放共享內(nèi)存塊:
            ?shmctl(iShm_id,IPC_RMID,0)<0
            ?調(diào)用 shmctl("Shared Memory Control",控制共享內(nèi)存)函數(shù)會(huì)返回一個(gè)共享內(nèi)存塊的相關(guān)信息。同時(shí) shmctl 允許程序修改這些信息。
            ?該函數(shù)的第一個(gè)參數(shù)是一個(gè)共享內(nèi)存塊標(biāo)識(shí)。要獲取一個(gè)共享內(nèi)存塊的相關(guān)信息,則為該函數(shù)傳遞 IPC_STAT 作為第二個(gè)參數(shù),同時(shí)傳遞一個(gè)指向一個(gè) struct shmid_ds 對(duì)象的指針作為第三個(gè)參數(shù)。
            ?要?jiǎng)h除一個(gè)共享內(nèi)存塊,則應(yīng)將 IPC_RMID 作為第二個(gè)參數(shù),而將 NULL 作為第三個(gè)參數(shù)。當(dāng)最后一個(gè)綁定該共享內(nèi)存塊的進(jìn)程與其脫離時(shí),該共享內(nèi)存塊將被刪除。
            ?應(yīng)當(dāng)在結(jié)束使用每個(gè)共享內(nèi)存塊的時(shí)候都使用 shmctl 進(jìn)行釋放,以防止超過(guò)系統(tǒng)所允許的共享內(nèi)存塊的總數(shù)限制。調(diào)用 exit 和 exec 會(huì)使進(jìn)程脫離共享內(nèi)存塊,
            ?但不會(huì)刪除這個(gè)內(nèi)存塊。 要查看其它有關(guān)共享內(nèi)存塊的操作的描述,請(qǐng)參考shmctl函數(shù)的手冊(cè)頁(yè)。

            共享內(nèi)存的總體大小是有限制的,這個(gè)大小通過(guò)SHMMAX參數(shù)來(lái)定義(以字節(jié)為單位),
            您可以通過(guò)執(zhí)行以下命令來(lái)確定 SHMMAX 的值:
            cat /proc/sys/kernel/shmmax

            修改共享內(nèi)存:
            ?設(shè)置 SHMMAX
            ?# >echo "2147483648" > /proc/sys/kernel/shmmax
            ?您還可以使用 sysctl 命令來(lái)更改 SHMMAX 的值:
            ?# sysctl -w kernel.shmmax=2147483648
            ?最后,通過(guò)將該內(nèi)核參數(shù)插入到 /etc/sysctl.conf 啟動(dòng)文件中,您可以使這種更改永久有效:
            ?# echo "kernel.shmmax=2147483648" >> /etc/sysctl.conf
            ====================================================================

            /*********************************************************
            ?*? filename:?ipc.c
            ?*? author:?wjy
            ?*? date:?20110509
            *********************************************************/
            #include <stdio.h>
            #include <stdlib.h>
            #include <string.h>
            #include <errno.h>
            #include <unistd.h>
            #include <sys/types.h>
            #include <sys/ipc.h>
            #include <sys/shm.h>
            #include <sys/stat.h>
            int main(int argc,char *argv[])
            {
            ?key_t shmid;
            ?char *p_addr,*c_addr;
            ?pid_t pid;
            ?if(argc != 2)
            ?{
            ??printf("Usage:program something",argv[0]);
            ??exit(0);
            ?}
            ?if((shmid = shmget(IPC_PRIVATE,1024,S_IRUSR|S_IWUSR)) == -1)
            ?{
            ??printf("create share memory error/n");
            ??exit(1);
            ?}
            ?pid = fork();
            ?if(pid > 0 )
            ?{
            ??p_addr = shmat(shmid,0,0);
            ??memset(p_addr,'/0',1024);
            ??strncpy(p_addr,argv[1],1024);
            ??wait(NULL);
            ?}
            ?else if (pid == 0)
            ?{
            ??sleep(1);
            ??c_addr = shmat(shmid,0,0);
            ??printf("Client get %s/n",c_addr);
            ??exit(0);
            ?}
            ?if(shmctl(shmid,IPC_RMID,0)<0)
            ?{
            ??printf("共享內(nèi)存釋放出錯(cuò)!!/n");
            ??return(-1);
            ?}
            ?else
            ??printf("釋放共享內(nèi)存成功!/n");
            }

            久久成人18免费网站| 久久婷婷五月综合国产尤物app | 要久久爱在线免费观看| 欧美日韩中文字幕久久伊人| 精品久久一区二区| 久久人人爽人爽人人爽av| 伊人久久大香线蕉AV一区二区| 国产A级毛片久久久精品毛片| 国产精品女同久久久久电影院| 99国内精品久久久久久久| 国产精品日韩欧美久久综合| 伊人久久成人成综合网222| 久久久久99精品成人片试看| 国产99久久九九精品无码| 无码八A片人妻少妇久久| 久久久久久亚洲AV无码专区| 久久国产乱子伦精品免费午夜| 久久天天躁夜夜躁狠狠躁2022| av无码久久久久久不卡网站| 久久亚洲天堂| 久久精品国产免费一区| 久久无码中文字幕东京热| 蜜桃麻豆www久久| 伊人久久综合精品无码AV专区| 久久精品一区二区三区中文字幕| 性欧美大战久久久久久久久| 久久99久久成人免费播放| 久久久久久午夜成人影院| 亚洲精品美女久久久久99小说| 亚洲天堂久久精品| 久久亚洲AV成人无码国产| 一级a性色生活片久久无| 97久久精品人人做人人爽| 久久66热人妻偷产精品9| 精品国产乱码久久久久久呢| 久久综合视频网站| 狠狠人妻久久久久久综合蜜桃| 久久噜噜电影你懂的| 97久久国产亚洲精品超碰热| 亚洲人成网亚洲欧洲无码久久| 久久青青草视频|