共享記憶體IPC入門學習

2021-06-18 09:57:33 字數 2378 閱讀 7317

系統建立ipc通訊(如訊息佇列、共享記憶體時)必須指定乙個id值。通常情況下,該id值通過ftok函式得到。

ftok原型如下:

key_t ftok( char * fname, int id )

fname就時你指定的檔名(該檔案必須是存在而且可以訪問的),id是子序號,

雖然為int,但是只有8個位元被使用(0-255)。

當成功執行的時候,乙個key_t值將會被返回,否則 -1 被返回。

在一般的unix實現中,是將檔案的索引節點號取出,前面加上子序號得到key_t的返回值。如指定檔案的索引節點號為65538,換算成16進製為 0x010002,而你指定的id值為38,換算成16進製為0x26,則最後的key_t返回值為0x26010002。

查詢檔案索引節點號的方法是: ls -i

以下為測試程式:

#include

#include

#include

#define ipckey 0x11

int main( void )

在成功獲取到key之後,就可以使用該key作為某種方法的程序間通訊的key值,例如shmget共享記憶體的方式。

shmget的函式原型為

int shmget( key_t, size_t, flag);

在建立成功後,就返回共享記憶體的描述符。在shmget中使用到的key_t就是通過ftok的方式生成的

例項:

#include #include #include #include #include #define size 1024

extern int errno;

int main()

//將共享記憶體連線到 可用位址上

if((shmptr = (char*)shmat(shmid, 0, 0)) == (void*)-1)

memcpy(shmptr, "hello world", sizeof("hello world"));

printf("share memory from %lx to %lx, content:%s\n",(unsigned long)shmptr, (unsigned long)(shmptr + size), shmptr);

//拆卸共享記憶體

if((shmctl(shmid, ipc_rmid, 0) < 0))

}多程序之間共享記憶體情況:

#include #include #include #include #include #include #include #include #define size 1024

extern int errno;

int main()

else if(pid == 0)

if((shmid = shmget(key, size, 0600)) < 0)

if((shmptr = (char*)shmat(shmid, 0, 0)) == (void*)-1)

//memcpy(shmptr, "hello world", sizeof("hello world"));

printf("child:pid is %d,share memory from %lx to %lx, content:%s\n",getpid(), (unsigned long)shmptr, (unsigned long)(shmptr + size

), shmptr);

printf("child process sleep 2 seconds\n");

sleep(2);

if((shmctl(shmid, ipc_rmid, 0) < 0))

exit(0);

}//parent

else

if((shmid = shmget(key, size, 0600|ipc_creat|ipc_excl)) < 0)

if((shmptr = (char*)shmat(shmid, 0, 0)) == (void*)-1)

memcpy(shmptr, "hello world", sizeof("hello world"));

printf("parent:pid is %d,share memory from %lx to %lx, content:%s\n",getpid(),(unsigned long)shmptr, (unsigned long)(shmptr + size

), shmptr);

printf("parent process sleep 2 seconds\n");

sleep(2);

if((shmctl(shmid, ipc_rmid, 0) < 0))

}waitpid(pid,null,0);

exit(0);

}

IPC 共享記憶體

共享記憶體 shared memory 是最簡單的程序間通訊方式,它允許多個程序訪問相同的記憶體,乙個程序改變其中的資料後,其他的程序都可以看到資料的變化。共享記憶體是程序間最快速的通訊方式 程序共享同一塊記憶體空間。訪問共享記憶體和訪問私有記憶體一樣快。不需要系統呼叫和核心入口。不造成不必要的記憶...

IPC 共享記憶體

a 意義 多個程序共享一部分物理記憶體。訪問快,方便 b 先建立共享記憶體 int shmget key t key,int size,int shm 1.key 標誌共享記憶體的鍵值 0 ipc private a key 0 a 意義 多個程序共享一部分物理記憶體。訪問快,方便 b 先建立共享記...

IPC 共享記憶體

程序可以將同一段共享記憶體連線到它們自己的位址空間中,所有程序都可以訪問共享記憶體中的位址。共享記憶體並未提供同步機制,使用訊號量進行同步。共享記憶體的特點 1 共享記憶體是程序間共享資料的一種最快的方法。乙個程序向共享的記憶體區域寫入了資料,共享這個記憶體區域的所有程序就可以立刻看到其中的內容。2...