概念
通俗的说就是两个进程同享一段公共的内存空间,这段空间就叫共享内存,共享内存的数据两个进程都可以访问,可对其写数据,也可对其读数据。共享内存是两个单独进程之间的通信,两个进程之间可以没有任何关系。
图解
内存共享函数
int shmget(key_t key, size_t size, int shmflg);
参数
key:这个共享内存段名字
size:共享内存大小
shmflg:由九个权限标志构成,它们的用法和创建文件时使用的mode模式标志是一样的
返回值:
成功返回一个非负整数,即该共享内存段的标识码;失败返回-1
void *shmat(int shmid, const void *shmaddr, int shmflg);
参数
shmid: 共享内存标识
shmaddr:指定连接的地址
shmflg:它的两个可能取值是SHM_RND和SHM_RDONLY
返回值:
成功返回一个指针,指向共享内存第一个节;失败返回-1
int shmdt(const void *shmaddr);
参数
shmaddr: 由shmat所返回的指针
返回值:
成功返回0;失败返回-1
注意:将共享内存段与当前进程脱离不等于删除共享内存段
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
参数
shmid:由shmget返回的共享内存标识码
cmd:将要采取的动作(有三个可取值),如下表
buf:指向一个保存着共享内存的模式状态和访问权限的数据结构
返回值:
成功返回0;失败返回-1
shmctl 函数cmd参数表
cmd | 说明 |
---|---|
IPC_STAT | 将shmid_ds结构中的数据设置为共享内存的当前关联值 |
IPC_SET | 在进程有足够的权限的前提下,把共享内存的当前关联值设置为shmid_ds结构中给出的值 |
IPC_RMID | 删除共享内存段 |
代码示例
writeshm.c
#include
#include
#include
#include
#define shm_key 123 //共享内存名称
int main()
{
//创建一个共享内存
int shmid=shmget(shm_key,1024,IPC_CREAT |0644 );
printf("shmid=%d\n",shmid);
if(shmid<0)
{
return 0;
}
//将进程附加到共享内存
struct shmid_ds buf;
shmctl(shmid,IPC_STAT,&buf);
printf("shm_size: %ld\n",buf.shm_segsz);
void *lp = shmat(shmid,NULL,0);
if(!lp)
{
return 0;
}
while(1)
{
sprintf((char *)lp,"%s","what your name?\n");
sleep(1);
}
//分离进程与共享内存
shmdt(lp);
shmctl(shmid,IPC_RMID,&buf);
return 0;
}
readshm.c
#include
#include
#include
#include
#define shm_key 123
int main()
{
//创建一个共享内存
int shmid=shmget(shm_key,1024,IPC_CREAT |0644 );
if(shmid<0)
{
return 0;
}
//将进程附加到共享内存
struct shmid_ds buf;
shmctl(shmid,IPC_STAT,&buf);
printf("shm_size: %ld\n",buf.shm_segsz);
void *lp = shmat(shmid,NULL,0);
if(!lp)
{
return 0;
}
while(1)
{
printf("%s\n",(char *)lp);
sleep(1);
}
//分离进程与共享内存
shmdt(lp);
//共享内存的销毁
shmctl(shmid,IPC_RMID,&buf);
return 0;
}
运行结果