Linux 共享内存 .

一、概念

共享内存是被多个进程共享的一部分物理内存,是进程间共享数据的最快的一种方法。

 

二、实现

分为两个步骤:

1、创建共享内存。

2、映射共享内存。

1、创建

  int shmget(key_t key, int size, int shmflg)

当key的取值为 IPC_PRIVATE 时,将创建一块新的共享内存。shmflg至少设为S_IRUSR|S_IWUSR否则会出现读写错误。成功返回内存标示符,失败返回-1。

2、映射

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

shmaddr为共享内存的起始地址。flag对内存的操作模式。通常命令可写为:shmat(shmid,NULL,0);

 

成功返回共享内存的起始地址,失败返回-1。

 

三、举例

  1. #include<sys/stat.h>   
  2. #include<sys/ipc.h>   
  3. #include<sys/shm.h>   
  4. #include<memory.h>   
  5. #include<fcntl.h>   
  6. #define PERM S_IRUSR|S_IWUSR   
  7.   
  8. int main(int argc ,char *argv[]){  
  9.         int shmid;  
  10.         pid_t pid;  
  11.         if(argc!=2){  
  12.                 printf("Usage: shmA [string]\n");  
  13.                 return -1;   
  14.         }  
  15.         if((shmid=shmget(IPC_PRIVATE,1024,PERM))<0){  
  16.                 printf("shared memory create error!\n");  
  17.                 _exit(1);  
  18.         }  
  19.         char *p;  
  20.         pid=fork();  
  21.         if(pid ==0){  
  22.                 sleep(1);  
  23.                 p=shmat(shmid,NULL,0);  
  24.                 memset(p,'\0',1024);  
  25.                 strcpy(p,argv[1]);  
  26.                 printf("already written!!! It's %s \n",p);  
  27.         }  
  28.         else{  
  29.                 wait(NULL);  
  30.                 p = shmat(shmid,NULL,0);  
  31.                 printf("read from memory %s \n",p);  
  32.         }  
  33.         return 0;  
  34. }  
  35.          
#include<sys/stat.h>
#include<sys/ipc.h>
#include<sys/shm.h>
#include<memory.h>
#include<fcntl.h>
#define PERM S_IRUSR|S_IWUSR

int main(int argc ,char *argv[]){
        int shmid;
        pid_t pid;
        if(argc!=2){
                printf("Usage: shmA [string]\n");
                return -1; 
        }
        if((shmid=shmget(IPC_PRIVATE,1024,PERM))<0){
                printf("shared memory create error!\n");
                _exit(1);
        }
        char *p;
        pid=fork();
        if(pid ==0){
                sleep(1);
                p=shmat(shmid,NULL,0);
                memset(p,'\0',1024);
                strcpy(p,argv[1]);
                printf("already written!!! It's %s \n",p);
        }
        else{
                wait(NULL);
                p = shmat(shmid,NULL,0);
                printf("read from memory %s \n",p);
        }
        return 0;
}
       

子进程写入argv[1],父进程输出argv[1]的值。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
shmobject.h 是一个 Linux 下循环队列内存共享的头文件。 循环队列是一种常用的数据结构,它具有固定大小的缓冲区,可以循环利用空间,实现高效的数据读写。在 Linux 系统中,循环队列的实现可以通过内存共享来进行。 shmobject.h 提供了一套函数接口,用于在进程间共享循环队列的内存。使用 shmobject.h,可以方便地在多个进程之间传递数据,并实现进程之间的通信。 shmobject.h 的主要功能有以下几个方面: 1. 创建和删除共享内存对象:shmobject.h 提供了函数接口来创建或删除共享内存对象。通过创建共享内存对象,多个进程可以访问同一块内存空间,使得数据可以在进程间共享。 2. 循环队列读写操作:shmobject.h 提供了函数接口来进行循环队列的读写操作。可以通过指定读写的位置和大小,将数据写入循环队列或从循环队列中读取数据。 3. 进程间同步:shmobject.h 通过信号量和互斥锁等机制,实现了进程间的同步。这样可以确保多个进程对共享内存的访问是互斥的,避免数据冲突和不一致性。 4. 错误处理:shmobject.h 提供了错误处理的机制,可以返回错误码和错误信息,方便程序员进行调试和错误处理。 总之,shmobject.h 是一个用于 Linux 系统下的循环队列内存共享的头文件,提供了一套函数接口,实现了进程间共享数据的功能,并且支持进程间同步和错误处理。使用 shmobject.h 可以方便地在 Linux 系统中进行进程间通信和数据传递。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值