网站制作好在百度里可以搜到吗,选择推广途径与原因,品牌全案营销策划,网站建设与域名备案进程通信的前提#xff1a;不同的进程看到同一份的资源
直接原理:同一块物理内存映射到不同进程的共享区 共享内存拆解#xff1a; 1.申请内存#xff0c;通过页表映射到进程地址空间 2.返回首地址#xff0c;便于进程利用 3.释放共享内存#xff0c;去关联 4.内存的申请…进程通信的前提不同的进程看到同一份的资源
直接原理:同一块物理内存映射到不同进程的共享区 共享内存拆解 1.申请内存通过页表映射到进程地址空间 2.返回首地址便于进程利用 3.释放共享内存去关联 4.内存的申请必须要系统调用确保空间不是私有的 5.利用先管理再组织不难猜到内核有个struct结构体管理起来 申请共享内存系统调用接口 size_t 创建共享内存大小单位是字节返回值为共享内存标识符失败返回-1
shmflg参数选项IPC_CREAT:如果存在返回不存在就创建
IPC_CREAT|IPC_EXCL : 不存在就创建存在就出错返回保证申请的共享内存一个是新的
IPC_EXCL:不单独使用
参数key:作为某一块共享内存的标识符拿到同一个key就可以看到同一块内存key存在struct描述对象中
利用路径和项目id创建一个唯一key 用于申请共享内存 路径本身就具有唯一性
实际运用时并不是直接拿到key而是拿到pathname 和 proj_id key vs shmid key创建共享内存的参数shmid 函数shmget的返回值 key操作系统内定唯一性 shmid只在进程内表示资源唯一性 查看共享资源 当进程结束时用户不主动关闭共享内存依然存在除非内核重启。
删除共享内存
ipcrm -m shmid key是系统使用的shmid是用户层使用。
挂接共享内存到地址空间建立进程和共享空间的关系 返回值void* 共享空间在地址空间的虚拟地址
shmid共享内存描述符
shamddr挂接的地址 系统决定
shmflg:挂接的权限 保持权限不变设为0
char* shamddr(char*)shmat(shmid,nullptr,0); nattch等于1表示有一个挂载当进程结束时会自动结束挂载或者调用shmdt函数在进程就能结束挂载
shmdt(shamddr);
在进程中删掉共享内存 共享内存的属性由struct ipc_perm保存猜测涉及到管理共享内存
cmd参数选项对共享内存的操作
shmctl(shmid,IPC_RMID,nullptr);
进程通过共享内存通信
当两个进程同时挂接到共享内存时两个进程实现通信。共享内存被挂载到进程的的地址空间直接在进程中通过虚拟地址访问。
comm.hpp代码
#ifndef __COMM_HPP__
#define __COMM_HPP__#includeiostream
#includestring
#includesys/ipc.h
#includecstring
#includesys/shm.h
#includesys/types.h
#includelog.hpp
using namespace std;
//共享内存大小一般建议4096的整数倍 1024字节1kb
const int size4096;
const string pathname/home/boki;
const int proj_id0x8888;
Log log;//获取key
//将GetKey和GetShoareMem都放在同一个头文件中保证获得的key相同
key_t GetKey()
{key_t kftok(pathname.c_str(),proj_id);if(k-1){log(Fatal,ftok error: %s,strerror(errno));exit(1);}log(Info,ftok success,key is : %d,k);return k;
}int GetShareMemHelper(int flag)
{key_t kGetKey();int shmidshmget(k,size,flag);if(shmid0){log(Fatal,creat share memory error: %s,strerror(errno));exit(2);}log(Info,create share memory success, shmid: %d,shmid);return shmid;
}
int CreateShm()
{return GetShareMemHelper(IPC_CREAT|IPC_EXCL|0666);
}
int GetShm()
{return GetShareMemHelper(IPC_CREAT);
}
#endif
process.a代码
#include comm.hppusing namespace std;
int main()
{// 创建共享内存int shmidCreateShm();//共享内存挂接到进程char* shamddr(char*)shmat(shmid,nullptr,0);while(true){coutclient sayshamddrendl;sleep(1);}//删除挂接关系shmdt(shamddr);//删除共享内存shmctl(shmid,IPC_RMID,nullptr);return 0;
}
process.b代码
#include comm.hppusing namespace std;
int main()
{// 创建共享内存int shmidGetShm();//共享内存挂接到进程char* shamddr(char*)shmat(shmid,nullptr,0);// ipc codewhile(true){char buffer[1024];coutPlease Enter ;fgets(shamddr,4096,stdin);}//删除挂接关系shmdt(shamddr);return 0;
}
效果 此时可以把shamddr看成malloc返回的地址且通信过程不再需要系统调用。 共享内存的机制特点 共享内存没有同步互斥保护机制 管道文件读端会阻塞等到写端打开而共享内存两端各自独立 共享内存是所有的进程通信中速度最快的 拷贝少管道通信至少拷贝4次用户-缓冲区-内核-缓冲区-屏幕 共享内存内部的数据由自己保护 查看共享内存属性 内存文件同步互斥保护机制
通过管道的机制每次写入信息到共享内存时向管道传入符号另一端管道文件接收到特殊符号才允许从内存中读取。