Linux 共享内存mmap,进程通信

这篇具有很好参考价值的文章主要介绍了Linux 共享内存mmap,进程通信。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

进程间通信是操作系统中重要的概念之一,使得不同的进程可以相互交换数据和进行协作。其中,共享内存是一种高效的进程间通信机制,而内存映射(mmap)是实现共享内存的一种常见方法。


一、存储映射 I/O

存储映射 I/O 是 一个磁盘文件 与 存储空间中的一个缓冲区相映射。于是, 当从缓冲区中取数据,就相当于读文件中的相应字节。于此类似,将数据存入缓冲区,则相应的字节就自动写入文件。这样, 就可在 不适用 read 和 write 函数的情况下,使用 地址(指针)完成 i/o 操作。

使用这种方法,首先应通知内核,将一个指定文件映射到存储区域中。这个映射工作可以通过 mmap 函数来实现。使用 mmap 系统调用,进程可以直接操作共享内存的指针,而不需要复杂的数据结构和同步机制。
Linux 共享内存mmap,进程通信,linux,linux,android,运维,mmap,存储映射

理解 共享内存
共享内存是一种特殊的内存区域,它可以被多个进程访问和操作。这意味着不同的进程可以直接读取或写入该共享内存区域中的数据。相比于其他进程间通信机制,共享内存具有较低的开销和高效的数据传输速度。


二、mmap, munmap

mmap 用于创建共享内存映射。munmap 用来 释放内存。

 #include <sys/mman.h>

 void *mmap(void *addr, size_t length, int prot, int flags,
           int fd, off_t offset);

 int munmap(void *addr, size_t length);
  1. void * mmap ( void * addr, size_t length , int prot , int flags , int fd , off_t offset ) ;

参数:

  • addr : 指定映射区的首地址。通常传 NULL / 0,表示让系统自动分配。
  • length :共享映射区的大小。
  • prot : 共享映射区的读写属性。
  • flags : 标注共享内存的共享属性。
  • fd :用于创建共享映射区的哪个文件的,文件描述符。
  • offset :

返回值:
Linux 共享内存mmap,进程通信,linux,linux,android,运维,mmap,存储映射

  • 成功 : 映射区的首地址。
  • 失败 : 返回 M AP_FAILED。
  1. int munmap ( void * addr , size_t length ) ;
    Linux 共享内存mmap,进程通信,linux,linux,android,运维,mmap,存储映射

三、父子进程间 mmap 通信

void sys_error(const char *str)
{
	perror(str);		
	exit(1);									// 正常退出程序
}

int var = 10;

int main(void)
{
	int fd;
	char *p;
	pid_t pid;

	fd = open("1.txt", O_RDWR);
	if(fd < 0)
	{
		sys_error("open error");
	}

	ftruncate(fd,100);								// 扩展空间大小
	int len = lseek(fd,0,SEEK_END);
	
	p = mmap(NULL, len, PROT_READ|PROT_WRITE, MAP_SHARED,fd, 0);		// 创建共享映射区
	if(p == MAP_FAILED)
	{
		sys_error("map error!");
	}
	close(fd);

	pid = fork();								 // 创建子进程
	if(pid == 0)
	{
		strcpy(p,"This is child");
		var = 100;
		printf("%s, Child: var = %d\n",p, var);
	}
	else
	{
		sleep(1);
		printf("Parent: %s,var = %d\n",p,var);
	}

	wait(NULL);											// 回收子进程
	munmap(p, len);										// 释放映射区

	return 0;
}

Linux 共享内存mmap,进程通信,linux,linux,android,运维,mmap,存储映射
var 是 全局变量,父子进程操作 全局变量时,读数据时 共享; 写数据时 复制。
上述代码中,子进程写数据时,是复制一份数据 后 对复制的数据进程修改。父进程 读数据时,全局变量还是原本的数值。

四、非血缘关系进程间 mmap 提通信

1.c 不断写数据:

void sys_error(const char *str)
{
	perror(str);		
	exit(1);
}

int main(void)
{
	int fd;
	char *p;
	int i = 0;

	fd = open("1.txt", O_RDWR);
	if(fd < 0)
	{
		sys_error("open error");
	}

	ftruncate(fd,100);
	int len = lseek(fd,0,SEEK_END);
	
	p = mmap(NULL, len, PROT_READ|PROT_WRITE, MAP_SHARED,fd, 0);
	if(p == MAP_FAILED)
	{
		sys_error("map error!");
	}
	close(fd);
	
	while(1)
	{
		sleep(1);
		*p = i;								// 不断写入数据
		i++;
	}
	
	munmap(p, len);
	return 0;
}

2.c 不断读数据

void sys_error(const char *str)
{
	perror(str);		
	exit(1);
}

int main(void)
{
	int fd;
	char *p;
	int i = 0;

	fd = open("1.txt", O_RDWR);
	if(fd < 0)
	{
		sys_error("open error");
	}

	ftruncate(fd,100);
	int len = lseek(fd,0,SEEK_END);
	
	p = mmap(NULL, len, PROT_READ|PROT_WRITE, MAP_SHARED,fd, 0);
	if(p == MAP_FAILED)
	{
		sys_error("map error!");
	}
	close(fd);
	
	while(1)
	{
		sleep(1);
		printf("*p = %d\n",*p);				// 不断读数据
	}
	
	munmap(p, len);
	return 0;
}

Linux 共享内存mmap,进程通信,linux,linux,android,运维,mmap,存储映射

五、mmap 匿名映射区

mmap 匿名映射区是在进程的虚拟内存空间中创建的一段没有对应物理文件的内存区域。它通常用于进程间通信和临时存储数据,不需要使用文件作为映射源。匿名映射区在 Linux 系统中非常常见。

在使用mmap系统调用创建匿名映射区时,传递给mmap函数的文件描述符参数(通常为-1)表明不会有一个与之相关联的文件。
mmap 函数的 参数二,可以为指定的大小。参数四 为 MAP_SHARED|MAP_ANONYMOUS

void sys_error(const char *str)
{
	perror(str);		
	exit(1);									// 正常退出程序
}

int var = 10;

int main(void)
{
	char *p;
	pid_t pid;

	p = mmap(NULL, 20, PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0);		// 创建共享映射区
	if(p == MAP_FAILED)
	{
		sys_error("map error!");
	}

	pid = fork();								 // 创建子进程
	if(pid == 0)
	{
		strcpy(p,"This is child");
		var = 100;
		printf("%s, Child: var = %d\n",p, var);
	}
	else
	{
		sleep(1);
		printf("Parent: %s,var = %d\n",p,var);
	}

	wait(NULL);											// 回收子进程
	munmap(p, 20);										// 释放映射区
	return 0;
}

总结

进程间共享内存映射(mmap)通信是一种高效、灵活的进程间通信机制。通过内存映射,不同的进程可以共享相同的数据区域,提高数据访问速度和性能。然而,在使用该机制时需要注意同步机制、内存管理和安全性等问题,以确保共享数据的正确性和安全性。文章来源地址https://www.toymoban.com/news/detail-646545.html

到了这里,关于Linux 共享内存mmap,进程通信的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Linux】进程间通信——管道/共享内存

    进程间通信( Inter-Process Communication,简称IPC )是指不同进程之间进行数据交换和共享信息的机制和技术。在操作系统中,每个进程都是独立运行的,有自己的地址空间和数据,因此进程之间需要一种机制来进行通信,以便彼此协调工作、共享数据或者进行同步操作。 进程间

    2024年02月16日
    浏览(45)
  • 进程间通信--共享内存详解【Linux】

    本文详细讲解了共享内存的原理和使用,并且通过实例代码角度来深度理解共享内存,下面就让我们开始吧。 数据传输:一个进程需要将它的数据发送给另一个进程 资源共享:多个进程之间共享同样的资源。 通知事件:一个进程需要向另一个或一组进程发送消息,通知它(

    2024年02月02日
    浏览(43)
  • (26)Linux 进程通信之共享内存(共享储存空间)

    共享内存是System V版本的最后一个进程间通信方式。 共享内存,顾名思义就是允许两个不相关的进程访问同一个逻辑内存,共享内存是两个正在运行的进程之间共享和传递数据的一种非常有效的方式。不同进程之间共享的内存通常为同一段物理内存。进程可以将同一段物理内

    2024年01月16日
    浏览(46)
  • Linux--进程间的通信-共享内存

    前文: Linux–进程间的通信-匿名管道 Linux–进程间的通信–进程池 Linux–进程间的通信-命名管道 对于两个进程,通过在内存开辟一块空间(操作系统开辟的),进程的虚拟地址通过页表映射到对应的共享内存空间中,进而实现通信 ; 特点和作用: 高效性: 共享内存是一种

    2024年04月26日
    浏览(42)
  • 【hello Linux】进程间通信——共享内存

    目录 前言: 1. System V共享内存 1. 共享内存的理解 2. 共享内存的使用步骤 3. 共享内存的使用         1. 共享内存的创建         查看共享内存         2. 共享内存的释放         3. 共享内存的挂接         4. 共享内存的去挂接 4. 共享内存的使用示例 1. 两进

    2024年02月01日
    浏览(105)
  • 【Linux】进程间的通信之共享内存

    利用 内存共享 进行进程间的通信的原理其实分为以下几个步骤: 在物理内存中创建一块共享内存。 将共享内存链接到要通信的进程的页表中,并通过页表进行进程地址空间的映射。 进程地址空间映射完毕以后返回首个虚拟地址,以便于进程之间进行通信。 根据共享内存的

    2024年02月09日
    浏览(50)
  • 【Linux】进程间通信——system V共享内存

    目录  写在前面的话 System V共享内存原理 System V共享内存的建立 代码实现System V共享内存 创建共享内存shmget() ftok() 删除共享内存shmctl() 挂接共享内存shmat() 取消挂接共享内存shmdt() 整体通信流程的实现          上一章我们讲了进程间通信的第一种方式 --- 管道,这一章我

    2024年02月14日
    浏览(43)
  • 【Linux】进程间通信 -- system V共享内存

    共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间,这些进程间数据传递不再涉及到内核,换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据 理解: 进程间通信,是专门设计的,用来IPC 共享内存是一种通信方式,所有想通信的进程

    2024年02月16日
    浏览(49)
  • Linux学习记录——이십 进程间通信(2)共享内存

    system是一套标准,独立于文件系统之外,是系统专门为通信而设计出来的内核模块,称之为system V的IPC通信机制。 共享内存的主要做法也是让两个毫不相关的进程看到同一份资源。 进程的地址空间内,栈和堆区之间有个共享区,堆是向上增长,栈是向下增长,重合的那个地方

    2023年04月24日
    浏览(40)
  • 【Linux】进程间通信 --- 管道 共享内存 消息队列 信号量

    等明年国庆去西藏洗涤灵魂,laozi不伺候这无聊的生活了 1. 通过之前的学习我们知道,每个进程都有自己独立的内核数据结构,例如PCB,页表,物理内存块,mm_struct,所以具有独立性的进程之间如果想要通信的话,成本一定是不低的。 2. a.数据传输:一个进程需要将它的数据

    2023年04月17日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包