Linux内存共享
SystemV內(nèi)存共享
創(chuàng)建共享內(nèi)存
/**
輸入:
key_t key 標(biāo)識(shí)符的規(guī)則size_t size 共享內(nèi)存大小int shmflg 讀寫(xiě)權(quán)限輸出: 成功返回共享內(nèi)存標(biāo)識(shí)符Id
失敗 -1說(shuō)明:
IPC_CREAT 若共享內(nèi)存不存在,則創(chuàng)建;若存在,則打開(kāi)IPC_CREAT | IPC_EXCL 若共享內(nèi)存不存在,則創(chuàng)建,若存在,則報(bào)錯(cuò)個(gè)別Linux系統(tǒng)(Ubuntu)需要加上0666參數(shù)進(jìn)行校驗(yàn),才能獲取共享內(nèi)存空間中的值#define PERM S_IRUSR | S_IWUSR | IPC_CREAT*/
int shmget(key_t key, size_t size, int shmflg);
連接共享內(nèi)存
/**
輸入:
int shmid 共享存儲(chǔ)idvoidr* addr 一般為0int flag 一般為0輸出: 成功 – 共享存儲(chǔ)段地址
失敗 -- -1說(shuō)明:
*/
void shmat(int shmid, voidr addr, int flag);
刪除共享存儲(chǔ)段地址
int shmdt(void* addr);
控制共享內(nèi)存
/**
輸入:
int shmid 共享存儲(chǔ)idint cmd 控制命令struct shmid_ds *buf輸出:
說(shuō)明:
控制命令:IPC_RMIDIPC_STATSHM_LOCKSHM_UNLOCK*/
int shmctl(int shmid, int cmd,struct shmid_ds *buf);
注意:
創(chuàng)建或打開(kāi)共享內(nèi)存錯(cuò)誤原因,errno儲(chǔ)存錯(cuò)誤原因。
EINVAL 參數(shù)size小于SHMMIN或大于SHMMAX。
EEXIST 預(yù)建立key所致的共享內(nèi)存,但已經(jīng)存在。
EIDRM 參數(shù)key所致的共享內(nèi)存已經(jīng)刪除。
ENOSPC 超過(guò)了系統(tǒng)允許建立的共享內(nèi)存的最大值(SHMALL )。
ENOENT 參數(shù)key所指的共享內(nèi)存不存在,參數(shù)shmflg也未設(shè)IPC_CREAT位。
EACCES 沒(méi)有權(quán)限。
ENOMEM 核心內(nèi)存不足。
#include <semaphore.h> #inlcude <stdlib.h> #include <stdio.h> #include <sys/types.h> #include <ipc.h> #include <sys/shm.h> #include <fcntl.h> sem_t *semid; int main(int argc, char** argv) {const char* semName = "sem_name_run";semid = sem_open(semName,O_CREAT,0644,0);if(semid == SEM_FAILED){perror("unable to create semaphore");unlink(semName);exit(-1);}if(fork() == 0){int shmid = shmget(0x123,1024,IPC_CREAT|0666);char* data;if(shmid <0){perror("shmget failed");exit(-1);}data = (char*)shmat(shmid,0,0);sprintf(data,"%s","xxx");sem_post(semid);}sem_wait(semid);int shmid;shmid = shmget(0x123,1024,IPC_CREAT|0666);char* data;data = shmat(0x123,0,0);printf("data: %s",data);sem_close(semid);sem_unlink(semName);return 0; }
總結(jié)
- 上一篇: Linux多线程同步——信号量
- 下一篇: Linux 线程学习之条件变量