linux_c开发(5-4)进程间通讯_共享内存通讯
来源:互联网 发布:数据脱敏 指导 编辑:程序博客网 时间:2024/06/05 09:38
共享内存
共享内存 是被多个进程共享的一部分物理内存。共享内存是进程间共享数据的一种最快方法,一个进程向共享内存写入了数据,共享这个内存的所有进程就可以立刻看到其中内容。
共享内存实现分为两个步骤
1、创建共享内存,使用shmget函数。
2、映射共享内存,将创建的这段共享内存映射到具体的进程空间去,使用shmat函数。
int shmget(key_t key,int size,int shmflg)
key标志共享内存的键值:O/IPC_PRIVATE.当key的取值为IPC/PRIVATE,则函数shmget()将创建一块新的共享内存;如果key的取值为0,而参数shmflg中又设置IPC_PRIVATE这个标志,则同样会创建一块新的共享内存。
返回值: 如果成功,返回共享内存标识符;如果失败,返回-1.
映射
int shmat(int shmat,char *shmaddr,int flag)
参数:
•shmid: shmget()函数返回的共享存储标识符
•flag: 决定以什么方式来确定映射的地址(通常为0)
返回值:
如果成功,则返回共享内存映射到进程中的地址;如果失败,则返回-1.
当一个进程不在需要共享内存时,需要把他从进程地址空间中脱离。
int shmdt(char *shmaddr)
头文件:shm_com.h
#define TEXT_SZ 2048struct shared_use_st{ int written_by_you; char some_text[TEXT_SZ];};
程序1用于读共享内存里面的数据
shm1.c
#include <unistd.h>#include <stdlib.h>#include <stdio.h>#include <string.h>#include <sys/types.h>#include <sys/ipc.h>#include <sys/shm.h>#include "shm_com.h"/* * 程序入口 * */int main(void){ int running=1; void *shared_memory=(void *)0; struct shared_use_st *shared_stuff; int shmid; /*创建共享内存*/ shmid=shmget((key_t)1234,sizeof(struct shared_use_st),0666|IPC_CREAT); if(shmid==-1) { fprintf(stderr,"shmget failed\n"); exit(EXIT_FAILURE); } /*映射共享内存*/ shared_memory=shmat(shmid,(void *)0,0); if(shared_memory==(void *)-1) { fprintf(stderr,"shmat failed\n"); exit(EXIT_FAILURE); } printf("Memory attached at %X\n",(int)shared_memory); /*让结构体指针指向这块共享内存*/ shared_stuff=(struct shared_use_st *)shared_memory; /*控制读写顺序*/ shared_stuff->written_by_you=0; /*循环的从共享内存中读数据,直到读到“end”为止*/ while(running) { if(shared_stuff->written_by_you) { printf("You wrote:%s",shared_stuff->some_text); sleep(1); //读进程睡一秒,同时会导致写进程睡一秒,这样做到读了之后再写 shared_stuff->written_by_you=0; if(strncmp(shared_stuff->some_text,"end",3)==0) { running=0; //结束循环 } } } /*删除共享内存*/ if(shmdt(shared_memory)==-1) { fprintf(stderr,"shmdt failed\n"); exit(EXIT_FAILURE); } exit(EXIT_SUCCESS);}
程序2,创建共享内存,共享数据
#include <unistd.h>#include <stdlib.h>#include <stdio.h>#include <string.h>#include <sys/types.h>#include <sys/ipc.h>#include <sys/shm.h>#include "shm_com.h"/* * 程序入口 * */int main(void){ int running=1; void *shared_memory=(void *)0; struct shared_use_st *shared_stuff; char buffer[BUFSIZ]; int shmid; /*创建共享内存*/ shmid=shmget((key_t)1234,sizeof(struct shared_use_st),0666|IPC_CREAT); if(shmid==-1) { fprintf(stderr,"shmget failed\n"); exit(EXIT_FAILURE); } /*映射共享内存*/ shared_memory=shmat(shmid,(void *)0,0); if(shared_memory==(void *)-1) { fprintf(stderr,"shmat failed\n"); exit(EXIT_FAILURE); } printf("Memory attached at %X\n",(int)shared_memory); /*让结构体指针指向这块共享内存*/ shared_stuff=(struct shared_use_st *)shared_memory; /*循环的向共享内存中写数据,直到写入的为“end”为止*/ while(running) { while(shared_stuff->written_by_you==1) { sleep(1);//等到读进程读完之后再写 printf("waiting for client...\n"); } printf("Ener some text:"); fgets(buffer,BUFSIZ,stdin); strncpy(shared_stuff->some_text,buffer,TEXT_SZ); shared_stuff->written_by_you=1; if(strncmp(buffer,"end",3)==0) { running=0; //结束循环 } } /*删除共享内存*/ if(shmdt(shared_memory)==-1) { fprintf(stderr,"shmdt failed\n"); exit(EXIT_FAILURE); } exit(EXIT_SUCCESS);}
共享内存通讯试验结果:
1 0
- linux_c开发(5-4)进程间通讯_共享内存通讯
- linux_c 开发(5-6)进程间通讯_信号量
- linux_c开发(5-1)进程间通讯_进程间通讯概念
- linux_c开发(5-2)进程间通讯_管道通讯
- linux_c开发(5-3)进程间通讯_信号通讯
- linux_c 开发(5-5)进程间通讯_消息队列
- 进程间通讯(四)共享内存
- 进程间通讯(四) 共享内存
- 进程间通讯-共享内存
- 进程间通讯----共享内存
- 进程间通讯---共享内存
- 进程间通讯-共享内存
- 进程间通讯:共享内存
- 进程通讯(共享内存)
- 进程间通讯概述管道通讯信号通讯共享内存
- 进程间的通讯方式_共享内存
- 进程间通讯-共享内存2(代码)
- 进程间通讯共享内存的具体步骤
- 《演说之禅》笔记
- Asp.net-知识总结(5)
- 关于asp错误'C:\inetpub\wwwroot\bg\#databases#\seablog.mdb'不是一个有效的路径。
- 关于block
- HDFS 的Trash回收站功能的配置、使用
- linux_c开发(5-4)进程间通讯_共享内存通讯
- JSP+servlet生成验证码并验证
- JAVA基础一大堆0802拷贝文件流+网络连接
- 文本分块切割
- MO and MMO
- 03_Android NDK中C语言调用Java代码,javah的使用,javap的使用以及生成签名,Android.mk的编写,C代码的编写
- UVA129 —— Krypton Factor (氪因素)
- 建堆的算法复杂度分析 O(n)
- STRUTS2为ACTION配置METHOD属性