共享内存区是最快的IPC(进程间通信)形式。
用共享内存从服务器拷贝文件数据到客户端:
共享内存基本API:
#include
#include
1. int shmget(key_t key,size_t size,int shmflg);
功能:用来创建共享内存
功能:将共享内存段连接到进程地址空间
shmaddr:指定连接的地址,因为内存地址是段页式管理,所以有可能传入的地址并不就是那一页的开头位置,所以传入一个地址,传出的仍然是一个地址,传出的是具体开始存储的地址。所以我们通常传入NULL,让编译器直接分配个合适的位置给我们。
shmflg:它的两个取值可能是SHM_RND和SHM_RDONLY.
例: void *p = shmat(shmid, NULL, 0);
返回值:成功返回一个指针,指向共享内存第一个节,失败返回-1;
3, int shmdt(const void *shmaddr);
功能:将共享内存段与当前进程脱离,但并不等于删除共享内存段
4, int shmctl(int shmid,int cmd,struct shmid_ds *buf);
功能:用于控制共享内存
cmd:将要采取的动作
1,IPC_STAT 把shmid_ds结构中的数据设置为共享内存的当前关联值
2,IPC_SET 在进程有足够权限的前提下,把共享内存的当前关联值设置为shmid_ds数据结构中给出的值
3,IPC_RMID 删除共享内存段
buf: 指向一个保存着共享内存的模式状态和访问权限的数据结构
例: shmctl(shmid, IPC_RMID, NULL);
//删除共享内存
若想要把旧的共享内存里面的内容保存下来,则传入一个地址,用来完成保存的功能
为什么链接共享内存时要设计shmid,创建时要传入key:
共享内存私有: