Linux--共享内存

进程间通信的方式

1、无名管道(只能单向发送或接收)

2、命名管道(只能单向发送或接收)

3、消息队列(可以发送,也能接收消息)

4、共享内存

(有一块公共内存,可挂载,即发即收。)

5、信号

6、信号量

(5.6.不作为进程间通信的方式,控制一个临界资源)

步骤:

1.创建/打开共享内存(shmget)

2.映射(shmat)

3.数据交换

(int *p=共享内存

printf("%s",p);//读取内存数据

strcpy("p","data");//向共享内存写入数据)

4.释放共享内存(shmdt)

5.关闭(shmctl)

原型:

c 复制代码
#include <sys/shm.h>
  
//1.创建或获取一个共享内存:成功返回共享内存id,失败返回-1
int shmget(key_t key, size_t size, int flag);
 
//2.连接共享内存到当前进程的地址空间:成功返回指向共享内存的指针,失败返回-1
void *shmat(int shm_id, const void *addr, int flag);
 
//3.断开与共享内存的连接:成功返回0,失败返回-1
int shmdt(void *addr);
 
//4.控制共享内存的相关信息:成功返回0,失败返回-1
int shmctl(int shm_id, int cmd, struct shmid_ds *buf);

例:

c 复制代码
//写入
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
 
//int shmget(key_t key, size_t size, int shmflg);
 
int main()
{
	int shmid;	
	char *shmaddr;
 
	key_t key;
	key = ftok(".",1);
 
	shmid = shmget(key,1024*4,IPC_CREAT|0666);
	if(shmid == -1){
		printf("shmget fail!\n");
		exit(-1);//正常退出返回0;出现异常返回-1
	}
 
	shmaddr = shmat(shmid,0,0);
	
	printf("shmget succeed!\n");
	strcpy(shmaddr,"laowang");
	
	sleep(5);
	shmdt(shmaddr);
	shmctl(shmid,IPC_RMID,0);
 
	printf("quit\n");
 
	return 0;
 
}
c 复制代码
//读取
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
 
//int shmget(key_t key, size_t size, int shmflg);
 
int main()
{
	int shmid;	
	char *shmaddr;
 
	key_t key;
	key = ftok(".",1);
 
	shmid = shmget(key,1024*4,0);
	if(shmid == -1){
		printf("shmget fail!\n");
		exit(-1);//正常退出返回0;出现异常返回-1
	}
 
	shmaddr = shmat(shmid,0,0);//0 系统分配地址,0 可读可写
	
	printf("shmget succeed!\n");
	printf("data=%s\n",shmaddr);
	
	shmdt(shmaddr);
 
	printf("quit\n");
 
	return 0;
 
}

先运行写入程序,再运行读取程序。

查看共享内存:ipcs -m

删除共享内存:ipcrm -m 共享内存id

相关推荐
神的孩子都在歌唱22 分钟前
常见的网络攻击方式及防御措施
运维·服务器·网络
Python×CATIA工业智造33 分钟前
详细页智能解析算法:洞悉海量页面数据的核心技术
爬虫·算法·pycharm
深度学习040733 分钟前
【Linux服务器】-安装ftp与sftp服务
linux·运维·服务器
无聊的小坏坏1 小时前
力扣 239 题:滑动窗口最大值的两种高效解法
c++·算法·leetcode
黎明smaly2 小时前
【排序】插入排序
c语言·开发语言·数据结构·c++·算法·排序算法
YuTaoShao2 小时前
【LeetCode 热题 100】206. 反转链表——(解法一)值翻转
算法·leetcode·链表
iteye_99392 小时前
让 3 个线程串行的几种方式
java·linux
YuTaoShao2 小时前
【LeetCode 热题 100】142. 环形链表 II——快慢指针
java·算法·leetcode·链表
CCF_NOI.2 小时前
(普及−)B3629 吃冰棍——二分/模拟
数据结构·c++·算法
渡我白衣2 小时前
Linux操作系统:再谈虚拟地址空间
linux