线程间通信的两种方式:消息队列、共享内存

一、消息队列


#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>

#include <unistd.h>
#include <string.h>
#include <strings.h>
#include <stdio.h>

#include <sys/ipc.h>
#include <sys/msg.h>
#include <sys/shm.h>
#include <semaphore.h> 
#include <pthread.h>

struct msgbuf{
   
	long mtype;
	char mtext[50];
};

void *routine1(void *arg)
{
   
	struct msgbuf buf;
	int msgid = (int)arg;
	int ret;
	
	while(1)
	{
   
		bzero(&buf,sizeof(buf));
		ret = msgrcv(msgid,&buf,sizeof(buf),30
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
共享内存消息队列两种常见的进程通信方式,它们各自具有一些优点和缺点。 共享内存的优点: 1. 高效:共享内存通信无需进行数据的复制,多个进程或线程可以直接访问同一块内存区域,减少了CPU和内存的开销,具有较低的延迟和较高的带宽。 2. 实时性:由于数据不需要复制和传输,共享内存通信延迟较低,能够满足对实时性要求较高的应用场景。 3. 灵活性:共享内存可以支持多种数据结构和数据类型的共享,适应不同的应用场景。 共享内存的缺点: 1. 同步与互斥:多个进程或线程可以直接访问共享内存,需要进行适当的同步和互斥操作,以避免数据的竞争和不一致性。这增加了编程的复杂性。 2. 局限性:共享内存通常只适用于同一台计算机上的进程或线程间通信,无法跨网络进行通信。 消息队列的优点: 1. 解耦和可靠性:消息队列实现了生产者和消费者之的解耦,生产者将消息发送到队列中,消费者从队列中获取消息进行处理。这种解耦可以提高系统的可靠性和可扩展性。 2. 异步通信:消息队列支持异步通信模式,生产者和消费者可以独立进行工作,无需等待对方的响应,从而提高系统的并发处理能力。 3. 跨平台与网络通信:消息队列通常支持跨平台和网络通信,可以在不同的计算机和进程之进行通信。 消息队列的缺点: 1. 延迟较高:由于消息需要经过队列传输,消息队列通信的延迟通常较高于共享内存。 2. 额外开销:消息队列需要维护消息的存储、传输和处理等额外开销,可能会增加一定的系统开销。 综上所述,选择使用共享内存还是消息队列,需要根据具体的应用场景和需求来决定。如果对实时性要求较高且需要高性能的通信方式,可以选择共享内存;如果需要解耦、异步和跨网络通信等特性,可以选择消息队列

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值