【嵌入式linux】进程间通信的几种方式

34 篇文章 1 订阅
31 篇文章 3 订阅

总结

1、pipo:具有亲缘关系的进程间,单工模式,数据在内存内

2、fifo: 可以用于任何进程间,双工,有文件名,数据在内存中。

3、signal:唯一的异步通信方式

4、msg:常常用于cs模型内,按消息类型访问,可有优先级。

5、shm:效率最高(直接访问内存),需要同步互斥机制。

6、sem:配合共享内存使用,用以实现同步和互斥。

 

 

管道:

  1. 无名管道PIPO
    1. 只能用于亲缘关系的进程间通信
    2. 半双工的通信模式。 
  2. 有名管道 FIFO
    1. 可以用于互不相关的两个进程间通信
    2. 先进先出规则

信号

  1. 内核产生信号,用户注册信号处理函数,来进行信号事件的处理

共享内存

  1. 最高效的进程间通信方式,进程可以直接读写内存,不需要任何数据的拷贝
  2. 多进程通信过程中。内核分配有共同的内存区,需要访问的进程可以将其映射到自己的私有地址空间。
  3. 但是需要依靠互斥锁或者信号量来保证同步性。防止阻塞。

 共享内存实现:

(1)、创建共享内存        shmget();

(2)、映射共享内存。       Shmat()

(3)、撤销共享内存映射   shmdt()

(4)、删除共享内存对象。Shmctl()

消息队列

  1. 消息队列由消息队列ID来唯一标识
  2. 消息队列是一个消息的列表,用户可以在队列中添加和读取消息。
  3. 消息队列可以按照类型来发送/接收消息

消息队列实现。

(1)创建或者打开消息队列      msgget();

(2)发送或者接收消息             msgsnd()/mesrcv()

(3)控制消息队列                    msgctl()

       信号量

       信号量是不同进程或者一个给定进程内部不同线程间同步的机制。

  1. semget()
  2. semop()
  3. semctl();
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
嵌入式Linux中的共享内存通信是一种高效的进程间通信方式,它允许多个进程在内存中共享数据,从而实现数据的快速传输和共享。下面是一种基本的共享内存通信的实现方法: 1. 创建共享内存区域: 在Linux中,可以使用shmget系统调用来创建共享内存区域。该系统调用需要指定共享内存的大小和权限等参数。创建成功后,会返回一个唯一的标识符。 2. 连接共享内存区域: 使用shmat系统调用将共享内存区域连接到进程的地址空间中。该系统调用需要指定共享内存的标识符,连接成功后,返回共享内存区域的起始地址。 3. 使用共享内存区域: 连接成功后,进程可以直接通过该内存区域的起始地址访问共享数据。可以使用指针或偏移量来访问不同的数据。 4. 分离共享内存区域: 当进程不再需要使用共享内存区域时,可以使用shmdt系统调用将其从进程的地址空间中分离。该系统调用需要指定共享内存的起始地址。 5. 删除共享内存区域: 当所有进程都不再使用该共享内存区域时,可以使用shmctl系统调用来删除共享内存区域。该系统调用需要指定共享内存的标识符。 需要注意的是,共享内存通信需要进程之间进行同步和互斥,以避免数据的不一致性和冲突。可以使用信号量、互斥锁等机制来实现进程间的同步和互斥操作。 以上是嵌入式Linux中实现共享内存通信的基本步骤,具体的实现方式可以根据需要进行调整和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值