`
isiqi
  • 浏览: 16702019 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

IPC——共享内存

阅读更多

共享内存的概念

共享内存是指被多个进程共享的一部分物理内存。共享内存是进程间共享数据的一种最快的方法,一个进程向共享内存的区域写了数据,共享这块内存区域的所有进程就可以立刻看到其中的内容了。

共享内存的实现可以分为两个部分:

一.创建共享内存,使用shmget函数

二.映射共享内存,将这块创建的共享内存映射到具体的进程空间中去,使用shmat函数

创建共享内存

int shmget(key_t key, int size, int 参数shmflag)

key:标识共享内存的键值:0/IPC_PRIVATE

key的取值为IPC_PRIVATE,则函数shmget()将创建一块新的共享内存;如果key的取值为0,而参数shmflag中又设置IPC_PRIVATE这个标识,则同样会创建一块新的共享内存。

返回值:如果成功,返回共享内存标识符;如果失败,返回-1

映射共享内存

int shmat(int shmid, char *shmaddr, int flag)

参数:

shmidshmget函数返回的共享内存标识符

flag:决定什么方式来确定映射的地址(通常为0

返回值:

如果成功,则返回共享内存映射到进程中的地址;如果失败,则返回-1

注意:当一个进程不再需要共享内存时,需要把它从进程地址空间中脱离。

使用下列函数:int shmdt(char * shmaddr) 来解除。

示例运行

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <errno.h> //
用于获取出错时的errno,供调试错误使用。
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>

#define PERM S_IRUSR|S_IWUSR //设置共享内存权限

int main(int argc,char **argv)
{
int shmid;
char *p_addr,*c_addr;

if(argc!=2)
{
fprintf(stderr,"Usage:%s\n\a",argv[0]);
exit(1);
}


if((shmid=shmget(IPC_PRIVATE,1024,PERM))==-1) //
依据设置的权值创建一块共享内存,返回共享内存标识符
{
fprintf(stderr,"Create Share Memory Error:%s\n\a",strerror(errno));
exit(1);
}


if(fork()) //
父进程写
{
p_addr=shmat(shmid,0,0); //
在父进程中映射共享内存,返回值为共享内存映射到进程中的地址
//
第二个参数为0,表示让操作系统自动为申请的空间开辟内存区域
memset(p_addr,'\0',1024); //
共享内存初始化
strncpy(p_addr,argv[1],1024);//
共享内存赋初值
wait(NULL); //
阻塞父进程,直到该父进程的子进程退出
exit(0);
}
else //
子进程读
{
sleep(1); //
如果子进程先运行的话,先使子进程阻塞,让父进程先运行
c_addr=shmat(shmid,0,0); //
返回共享内存映射到该子进程中的地址

printf("Client get %s\n",c_addr);
exit(0);
}
}

运行结果:(./shmem 123456)

Client get 123456

分享到:
评论

相关推荐

    Linux学习笔记Linux学习资料Linux教程

    【linux学习笔记--19】POSIX IPC——共享内存.doc 【linux学习笔记-10】Linux进程相关系统调用(三).doc 【linux学习笔记-11】守护进程daemon.doc 【linux学习笔记-12】守护进程的日志实现.doc 【linux学习笔记-13...

    linux系统进程间通信——共享内存(System V版本)

    之前用过Prosix版本的共享内存和信号量,一直没有实践System V版本的,主要是因为其信号量集的概念操作有些复杂,今天试着写一个SV版本的共享内存进程间通信,使用信号量同步。程序提供了几个简单的用于操作SV版本...

    非常宝贵的LINUX学习笔记

    【linux学习笔记-1】使用GDB调试简单的用户程序 【linux学习笔记-2】父子进程共享文件描述符 【linux学习笔记-3】文件操作(stat,chmod,umask) 【linux学习笔记-4】进程...【linux学习笔记--19】POSIX IPC——共享内存

    PHP与C++进行IPC命名管道共享内存通信

    本文将深入探讨如何使用PHP和C++通过IPC的两种常见机制——命名管道(Named Pipes)和共享内存(Shared Memory)来实现跨进程通信。这两种技术在高效率的系统设计中尤其重要。 首先,我们来看命名管道。命名管道是...

    c++ 操作共享内存代码

    在本教程中,我们将探讨一种高效的IPC机制——共享内存(Shared Memory),并关注如何使用C++来操作它。共享内存允许多个进程直接访问同一块内存区域,从而提供高速的数据交换能力。 标题中的“c++ 操作共享内存...

    进行通信,共享内存方式

    在给定的标题“进行通信,共享内存方式”中,我们聚焦于一种高效的IPC机制——共享内存。共享内存允许多个进程访问同一块内存区域,从而实现数据的快速传递和同步。 共享内存的优点在于它提供了直接的数据访问,...

    XXX_16xxx65_xxx898_共享内存_xxxbb12345_内存共享_

    尽管这些数字无法提供直接的技术信息,但它们强调了主题的核心——共享内存。 共享内存的概念源自操作系统理论,它允许两个或更多个进程共享同一块物理内存。在C++中,我们可以使用POSIX线程库(pthread)或者Boost...

    shareMemory.zip

    "shareMemory.zip"文件提供了一种解决方案——通过共享内存实现MATLAB/Simulink与第三方软件之间的通信。本文将深入探讨这一技术的原理、实现方法以及实际应用。 共享内存是一种有效的进程间通信(IPC)机制,它...

    易语言读写共享内存源码-易语言

    在这个“易语言读写共享内存源码”中,我们可以深入学习到如何在易语言环境下处理进程间通信(IPC)的一种常见技术——共享内存。 共享内存是一种高效的进程间通信方式,它允许多个进程直接读取和写入同一块内存...

    SharedMemoryTest:共享内存IPC测试

    共享内存是一种有效的进程间通信(IPC,Inter-Process Communication)机制,它允许不同的进程访问同一块内存区域,从而实现数据的快速交换。在本项目"SharedMemoryTest"中,我们看到的是一个用Pascal语言实现的共享...

    sem.rar_linux内存共享

    本资源“sem.rar_linux内存共享”聚焦于一种高效且直接的IPC方式——共享内存,以及配合使用的同步原语——信号量。共享内存允许不同进程访问同一块内存区域,而信号量则用于控制对这部分内存的访问权限,防止数据...

    操作系统的进程通信:共享内存、管道和消息队列的应用实现与解析

    内容概要:本文档详细介绍了MUC操作系统中三种不同的进程通信方式——共享内存、管道通信和消息队列的具体实现步骤与实验细节。每个部分不仅涵盖了相关概念和技术原理的简要介绍,还提供了一段或多段实际可操作性的...

    操作系统的全面知识——作业 进程 内存 设备 文件等管理

    进程间通信(IPC)机制,如管道、信号量、消息队列和共享内存,使得进程之间可以协同工作。此外,多线程也是现代操作系统中常见的一种进程组织形式,线程是进程内的执行单元,共享同一内存空间,允许并发执行。 **...

    linux ipc 共享资源程序实例

    Linux内核提供了多种IPC机制,包括管道(pipe)、消息队列(message queue)、信号量(semaphore)以及共享内存(shared memory)等。 本次实验的目标是通过具体的程序实例来演示Linux内核中IPC机制之一——管道的...

    5_sysv_shm

    本文将深入探讨其中的一种方法——System V共享内存(System V Shared Memory)。System V共享内存允许不同进程访问同一块内存空间,提高了通信效率。"5_sysv_shm"这个压缩包文件很可能包含了相关示例代码,帮助我们...

    android IPC及原理简介

    首先,Linux系统提供了多种传统的IPC方式,如socket、命名管道(named pipe)、消息队列(message queue)、信号(signal)以及共享内存(share memory)。这些机制在Java系统中同样适用,包括Android应用程序。然而...

    Linux下C语言编程——进程通信

    本篇主要讨论Linux下的几种进程通信机制,包括POSIX无名信号量、System V信号量、System V消息队列以及System V共享内存。 1. **POSIX 无名信号量** POSIX无名信号量是用于同步和保护共享资源的一种机制。信号量的...

    【Qt】进程间通信之QSharedMemory程序.rar

    在本文中,我们将深入探讨Qt库中的一个关键特性——QSharedMemory模块,它在进程间通信(IPC,Inter-Process Communication)中扮演着重要角色。QSharedMemory是Qt提供的一种高效且灵活的方式来实现不同进程之间的...

    IPC是一个c++库,在Windows上使用共享内存提供进程间通信。可以使用。net包装器,它也允许与c++交互。——微软/ IPC

    IPC IPC is a C++ library that provides inter-process communication using shared memory on Windows. A .NET wrapper is available which allows interaction with C++ as well. Integration with is available ...

Global site tag (gtag.js) - Google Analytics