六月丁香五月婷婷,丁香五月婷婷网,欧美激情网站,日本护士xxxx,禁止18岁天天操夜夜操,18岁禁止1000免费,国产福利无码一区色费

學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 電腦硬件知識 > 內(nèi)存知識 > 電腦共享內(nèi)存在哪里?

電腦共享內(nèi)存在哪里?

時(shí)間: 本達(dá)868 分享

電腦共享內(nèi)存在哪里?

  電腦共享內(nèi)存在哪里?共享內(nèi)存指在多處理器的計(jì)算機(jī)系統(tǒng)中,可以被不同中央處理器(CPU)訪問的大容量內(nèi)存。下面學(xué)習(xí)啦小編給大家介紹下電腦共享的相關(guān)知識,希望對大家有幫助!

  電腦共享內(nèi)存在哪里?

  共享內(nèi)存指 (shared memory)在多處理器的計(jì)算機(jī)系統(tǒng)中,可以被不同中央處理器(CPU)訪問的大容量內(nèi)存。由于多個CPU需要快速訪問存儲器,這樣就要對存儲器進(jìn)行緩存(Cache)。任何一個緩存的數(shù)據(jù)被更新后,由于其他處理器也可能要存取,共享內(nèi)存就需要立即更新,否則不同的處理器可能用到不同的數(shù)據(jù)。共享內(nèi)存是 Unix下的多進(jìn)程之間的通信方法 ,這種方法通常用于一個程序的多進(jìn)程間通信,實(shí)際上多個程序間也可以通過共享內(nèi)存來傳遞信息。

  工作原理

  由于多個CPU需要快速訪問存儲器,這樣就要對存儲器進(jìn)行緩存(Cache)。任何一個緩存的數(shù)據(jù)被更新后,由于其他處理器也可能要存取,共享內(nèi)存就需要立即更新,否則不同的處理器可能用到不同的數(shù)據(jù)。

  下面實(shí)例演示了使用shmget函數(shù)創(chuàng)建一塊共享內(nèi)存。程序中在調(diào)用shmget函數(shù)時(shí)指定key參數(shù)值為IPC_PRIVATE,這個參數(shù)的意義是創(chuàng)建一個新的共享內(nèi)存區(qū),創(chuàng)建成功后使用shell命令ipcs來顯示系統(tǒng)下共享內(nèi)存的狀態(tài)。命令參數(shù)-m為只顯示共享內(nèi)存的狀態(tài)。

  (1)在vi編輯器中編輯該程序如下:程序清單14-8 create_shm.c 使用shmget函數(shù)創(chuàng)建共享內(nèi)存#include <sys/types.h>#include <sys/ipc.h>#include <sys/shm.h>#include <stdlib.h>#include <stdio.h>#define BUFSZ 4096int main ( void ){int shm_id; /*共享內(nèi)存標(biāo)識符*/shm_id=shmget(IPC_PRIVATE, BUFSZ, 0666 ) ;//shm_id=shmget(999,BUFSZ,0666|O_CREAT);if (shm_id < 0 ) { /*創(chuàng)建共享內(nèi)存*/perror( "shmget" ) ;exit ( 1 );}printf ( "successfully created segment : %d \n", shm_id ) ;system( "ipcs -m"); /*調(diào)用ipcs命令查看IPC*/exit( 0 );}

  (2)在shell中編譯該程序如下:$gcc create_shm.c -o create_shm

  (3)在shell中運(yùn)行該程序如下:$./ create_shmsuccessfully created segment : 2752516------ Shared Memory Segments --------key shmid owner perms bytes nattch status0x0000000 66root 600 393216 2 dest0x00000 5209root 666 4096 00x0056a4d5 2686978 root 600 488 10x0056a4d6 2719747 root 600 131072 1root 666 4096 0

  上述程序中使用shmget函數(shù)來創(chuàng)建一段共享內(nèi)存,并在結(jié)束前調(diào)用了系統(tǒng)shell命令ipcs –m來查看當(dāng)前系統(tǒng)IPC狀態(tài)。

  注意事項(xiàng)

  共享內(nèi)存相比其他幾種方式有著更方便的數(shù)據(jù)控制能力,數(shù)據(jù)在讀寫過程中會更透明。當(dāng)成功導(dǎo)入一塊共享內(nèi)存后,它只是相當(dāng)于一個字符串指針來指向一塊內(nèi)存,在當(dāng)前進(jìn)程下用戶可以隨意的訪問。缺點(diǎn)是,數(shù)據(jù)寫入進(jìn)程或數(shù)據(jù)讀出進(jìn)程中,需要附加的數(shù)據(jù)結(jié)構(gòu)控制。

  如何創(chuàng)建編輯

  共享內(nèi)存是存在于內(nèi)核級別的一種資源,在shell中可以使用ipcs命令來查看當(dāng)前系統(tǒng)IPC中的狀態(tài),在文件系統(tǒng)/proc目錄下有對其描述的相應(yīng)文件。函數(shù)shmget可以創(chuàng)建或打開一塊共享內(nèi)存區(qū)。

  函數(shù)原型如下:#include <sys/shm.h>int shmget( key_t key, size_t size, int flag );

  函數(shù)中參數(shù)key用來變換成一個標(biāo)識符,而且每一個IPC對象與一個key相對應(yīng)。當(dāng)新建一個共享內(nèi)存段時(shí),size參數(shù)為要請求的內(nèi)存長度(以字節(jié)為單位)。

  注意:內(nèi)核是以頁為單位分配內(nèi)存,當(dāng)size參數(shù)的值不是系統(tǒng)內(nèi)存頁長的整數(shù)倍時(shí),系統(tǒng)會分配給進(jìn)程最小的可以滿足size長的頁數(shù),但是最后一頁的剩余部分內(nèi)存是不可用的。

  當(dāng)打開一個內(nèi)存段時(shí),參數(shù)size的值為0。參數(shù)flag中的相應(yīng)權(quán)限位初始化ipc_perm結(jié)構(gòu)體中的mode域。同時(shí)參數(shù)flag是函數(shù)行為參數(shù),它指定一些當(dāng)函數(shù)遇到阻塞或其他情況時(shí)應(yīng)做出的反應(yīng)。

1343448