一步一步学Linux C:共享内存通信实例

共享内存是LUNIX 系统中最底层的通信机制,也是最快速的通信机制。共享内存通过两个或多个进程共享同一块内存区域来实现进程间的通信。通常是由一个进程创建一块共享

内存区域,然后多个进程可以对其进行访问,一个进程将要传出的数据存放到共享内存中,另一个或多个进程则直接从共享内存中读取数据。因此这种通信方式是最高效的进程间通信方式。但实际的问题在于,当两个或多个进程使用共享内存进行通信时,同步问题的解决显得尤为重要,否则就会造成因不同进程同时读写一块共享内存中的数据而发生混乱。在通常的情况下,通过使用信号量来实现进程的同步。

以上两个程序是一个进程间通信的例子。这两个程序分别在不同的进程中运行,使用了共享内存进行通信。b从键盘读入数据,存放在共享内存中。a则从共享内存中读取数据,显示到屏幕上。由于没有使两个进程同步,显示的内容将是杂乱无章的,对这一问题的处理将在进一步学习有关同步的操作之后完成。

实例b程序负责向共享内存中写入数据,a程序负责从内存中读出共享的数据,它们之间并没有添加同步操作。

b.c

  1. #include <sys/types.h>   
  2. #include <sys/ipc.h>   
  3. #include <sys/shm.h>   
  4. #include <stdio.h>   
  5.   
  6. #define BUF_SIZE 1024   
  7. #define MYKEY 25   
  8. int main()  
  9. {  
  10.     int shmid;  
  11.     char *shmptr;  
  12.   
  13.     if((shmid = shmget(MYKEY,BUF_SIZE,IPC_CREAT)) ==-1)  
  14.     {  
  15.     printf("shmget error \n");  
  16.     exit(1);  
  17.     }  
  18.   
  19.     if((shmptr =shmat(shmid,0,0))==(void *)-1)  
  20.     {  
  21.     printf("shmat error!\n");  
  22.     exit(1);  
  23.     }  
  24.   
  25.     while(1)  
  26.     {  
  27.     printf("input:");  
  28.     scanf("%s",shmptr);  
  29.     }  
  30.   
  31.     exit(0);  
  32. }  

a.c

  1. #include <stdio.h>   
  2. #include <sys/types.h>   
  3. #include <sys/ipc.h>   
  4. #include <sys/shm.h>   
  5.   
  6. #define BUF_SIZE 1024   
  7. #define MYKEY 25   
  8. int  main()  
  9. {  
  10.     int shmid;  
  11.     char * shmptr;  
  12.   
  13.     if((shmid = shmget(MYKEY,BUF_SIZE,IPC_CREAT)) ==-1)  
  14.     {  
  15.     printf("shmget error!\n");  
  16.     exit(1);  
  17.     }  
  18.   
  19.     if((shmptr = shmat(shmid,0,0)) == (void *)-1)  
  20.     {  
  21.     printf("shmat error!\n");  
  22.     exit(1);  
  23.     }  
  24.   
  25.     while(1)  
  26.     {  
  27.     printf("string :%s\n",shmptr);  
  28.     sleep(3);  
  29.     }  
  30.   
  31.     exit(0);  
  32. }  
Linux C

 

Linux C
Linux系统提供了各种系统调用API用于进程之间的通信:     无名管道PIPE     命名管道FIFO     消息队列     共享内存     信号量     文件锁     信号signal.... 其中还包括system V和POSIX 两种接口标准,除此之外,Linux系统自身还扩展了自己的一套API接口用于进程间通信,比如signalfd、timerfd、eventfd等。 本视频教程为《Linux系统编程》第05期,本期课程将会带领大家学习Linux下将近15种进程间通信IPC工具的使用,了解它们的通信机制、编程实例、使用场景、内核中的实现以及各自的优缺点。 本课程会提供PDF版本的PPT课件和代码,学员购买课程后可到课程主页自行下载 嵌入式自学路线指导图: ------------------------------------------------------------------------------------------------------                    《嵌入式工程师自我修养》嵌入式自学系列教程                                           作者:王利涛 ------------------------------------------------------------------------------------------------------ 一线嵌入式工程师精心打造,嵌入式学习路线六步走:  第 1 步:Linux三剑客 零基础玩转Linux+Ubuntu Git零基础实战:Linux开发技能标配 vim从入门到精通基础篇:零基础学习vim基本命令 vim从入门到精通定制篇:使用插件打造嵌入式开发IDE makefile工程实践基础篇:从零开始一步一步写项目的Makefile makefile工程实践第2季:使用Autotools自动生成Makefile 软件调试基础理论 printf打印技巧 Linux内核日志与打印 使用QEMU搭建u-boot+Linux+NFS嵌入式开发环境 第 2 步:C语言嵌入式Linux高级编程 第1期:C语言进阶学习路线指南 第2期:计算机架构与ARM汇编程序设计 第3期:程序的编译、链接和运行原理 第4期:堆栈内存管理 第6期:数据存储与指针 第7期:嵌入式数据结构与Linux内核的OOP思想 第8期:C语言的模块化编程 第9期:CPU和操作系统入门       搞内核驱动开发、光会C语言是不行的!       你还需要学习的有很多,包括:计算机体系架构、ARM汇编、程序的编译链接运行原理、CPU和操作系统原理、堆栈内存管理、指针、linux内核中的面向对象思想、嵌入式系统架构、C语言的模块化编程..... 第 3 步:Linux系统编程 第00期:Linux系统编程入门 第01期:揭开文件系统的神秘面纱 第02期:文件I/O编程实战 第03期:I/O缓存与内存映射 第04期:打通进程与终端的任督二脉 第05期:进程间通信-------------------we are here!‍      第 4 步:Linux内核编程‍     练乾坤大挪移,会不会九阳神功,是一道坎。搞驱动内核开发,懂不懂内核也是一道坎。 第 5 步:嵌入式驱动开发     芯片原理、datasheet、硬件电路、调试手段、总线协议、内核机制、框架流程.... 第 6 步:项目实战     嵌入式、嵌入式人工智能、物联网、智能家居...
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页