共享内存:开辟一块内存,同一主机上的进程可以访问。
编程模型
A B
创建key ftok 创建key
创建共享内存 shmget 获取共享内存
挂载共享内存 shmat 挂载共享内存
使用共享内存 *p 使用共享内存
卸载共享内存 shmdt 卸载共享内存
获取共享内存状态 shmctl
删除共享内存 shmctl
创建key ftok 创建key
创建共享内存 shmget 获取共享内存
挂载共享内存 shmat 挂载共享内存
使用共享内存 *p 使用共享内存
卸载共享内存 shmdt 卸载共享内存
获取共享内存状态 shmctl
删除共享内存 shmctl
创建共享内存需要确定主机上一个位置。这个位置必须唯一,key是一个唯一的整数,这个整数由一个文件的偏移量来确定。
ftok从一个文件名获得一个唯一的整数key
ftok从一个文件名获得一个唯一的整数key
# include <sys/types.h>
# include <sys/ipc.h>
# include <sys/ipc.h>
key_t ftok(
const char *pathname,//文件名
int proj_id);//1-255的整数 保护码
const char *pathname,//文件名
int proj_id);//1-255的整数 保护码
ftok使用文件的偏移量经过保护码的设置得到一个整数。这个正整数用来确定一个唯一的地址。
shm:share memory
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/ipc.h>
#include <sys/shm.h>
int shmget(//成功返回shmid,失败返回-1
key_t key, //ftok的返回值 一个唯一的整数
size_t size, //大小
int shmflg);//方式 IPC_CREAT
key_t key, //ftok的返回值 一个唯一的整数
size_t size, //大小
int shmflg);//方式 IPC_CREAT
void *shmat(//成功返回内存地址,失败返回-1
int shmid,//shmget的返回值
const void *shmaddr, //设置挂载地址 建议NULL,由系统选择挂载地址
int shmflg);//挂载后的内存使用方式 SHM_RDONLY
int shmid,//shmget的返回值
const void *shmaddr, //设置挂载地址 建议NULL,由系统选择挂载地址
int shmflg);//挂载后的内存使用方式 SHM_RDONLY
int shmdt(
const void *shmaddr);//shmat的返回值
const void *shmaddr);//shmat的返回值
共享内存的数据是什么格式?
数据流 stream
数据有没有边界?
没有边界
数据有没有顺序?
没有
数据有没有状态
管道的数据没有状态 shm的数据会保存最后一个
单工?双工?
双工
ls -a
ipcs -a 查看shm sem msg
-m shm
-s sem
-q msg
ipcs -a 查看shm sem msg
-m shm
-s sem
-q msg
ipcrm -a
-m shm
-s sem
-q msg
-m shm
-s sem
-q msg
int shmctl(
int shmid, //指定shm的id
int cmd, //操作方式
IPC_STAT 获取shm的状态
IPC_RMID 删除shm
struct shmid_ds *buf);//状态结构体,保存shm的信息
int shmid, //指定shm的id
int cmd, //操作方式
IPC_STAT 获取shm的状态
IPC_RMID 删除shm
struct shmid_ds *buf);//状态结构体,保存shm的信息
A
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdlib.h>
#include <signal.h>
int shmid;
void hand(int s){
if(s == 2){
printf("删除共享内存!\n");
shmctl(shmid,IPC_RMID,0);
printf("bye bye!");
exit(0);
}
}
int main(){
key_t key;
int* p = NULL;
signal(2,hand);
//创建key 得到确定唯一内存的整数
key = ftok(".",100);
if(-1 == key) printf("ftok error:%m\n"),exit(-1);
printf("ftok %m\n");
//创建shm
shmid = shmget(key,4,IPC_CREAT|0666);
if(-1 == shmid) printf("Creat share memory error:%m\n"),exit(-1);
printf("Creat share memory %m!\n");
//挂载shm
p = shmat(shmid,NULL,SHM_RDONLY);//只读方式挂载
if((void*)-1 == p) printf("shmat error:%m\n"),/*删除shm*/exit(-1);
printf("shmat %m\n");
//使用shm
//int i = *p;
while(1){
//if(i != *p)
sleep(1);
printf(">>%d\n",*p);
//i = *p;
}
return 0;
}
B
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdlib.h>
int main(){
//创建key
key_t key = ftok(".",100);
//得到shmA中创建的shmid
int shmid = shmget(key,0,0);
//挂载
int* p = shmat(shmid,NULL,0);
//使用
int i = 0;
while(1){
*p = i++;
sleep(1);
}
return 0;
}