Qt 多进程通信之消息队列

71 篇文章 4 订阅

服务端:

#include <fcntl.h>           /* For O_* constants */
#include <sys/stat.h>        /* For mode constants */
#include <mqueue.h>
#include <unistd.h>
#include <syslog.h>

#define MQNAME  "/fifo1"

mqd_t m_mq;//message queue object
bool bExitThread = false;//exit thread condition
pthread_t g_thread;//thread object

void* Process(void* args)
{
    while(true){
        if(bExitThread){
            break;
        }
        char cData[1024] = {"123"};
        int nSend = mq_send(m_mq, cData, strlen(cData), 0);//nonblock
        if(errno == EAGAIN){
            syslog(LOG_DEBUG, "EAGAIN");
        }
        if(errno == EBADF){
            syslog(LOG_DEBUG, "EBADF");
        }
        if(errno == EINTR){
            syslog(LOG_DEBUG, "EINTR");
        }
        if(errno == EINVAL){
            syslog(LOG_DEBUG, "EINVAL");
        }
        if(errno == EMSGSIZE){
            syslog(LOG_DEBUG, "EMSGSIZE");
        }
        if(errno == ETIMEDOUT){
            syslog(LOG_DEBUG, "ETIMEDOUT");
        }
        usleep(1000 * 1000);//sleep one second
    }
}

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    m_mq = mq_open(MQNAME, O_RDWR | O_CREAT, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH, NULL);

    mq_attr m_attr;
    mq_getattr(m_mq, &m_attr);// get attribute from mq

    m_attr.mq_flags |= O_NONBLOCK;
    mq_setattr(m_mq, &m_attr, NULL);//set nonblock

    pthread_create(&g_thread, NULL, Process, this);//start thread
}

MainWindow::~MainWindow()
{
    bExitThread = true;//break-thread signal
    pthread_join(g_thread, NULL); //wait thread exit
    mq_close(m_mq); //close mq object
    mq_unlink(MQNAME);//delete mq from kernel
    delete ui;
}


客户端:

#include <fcntl.h>           /* For O_* constants */
#include <sys/stat.h>        /* For mode constants */
#include <mqueue.h>
#include <unistd.h>
#include <syslog.h>
#define MQNAME  "/fifo1"

mqd_t m_mq;
bool bExitThread = false;
pthread_t g_thread;

void* Process(void* args)
{
    while(true){
        if(bExitThread){
            break;
        }
        char cData[8192] = {0};
        ssize_t nRecv = mq_receive(m_mq, cData, 8192, 0);
        if(errno == EAGAIN){
            syslog(LOG_DEBUG, "EAGAIN");
        }
        if(errno == EBADF){
            syslog(LOG_DEBUG, "EBADF");
        }
        if(errno == EINTR){
            syslog(LOG_DEBUG, "EINTR");
        }
        if(errno == EINVAL){
            syslog(LOG_DEBUG, "EINVAL");
        }
        if(errno == EMSGSIZE){
            syslog(LOG_DEBUG, "EMSGSIZE");
        }
        if(errno == ETIMEDOUT){
            syslog(LOG_DEBUG, "ETIMEDOUT");
        }
        usleep(1000 * 1000);
    }
}

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    m_mq = mq_open(MQNAME, O_RDWR | O_CREAT, S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH, NULL);
    pthread_create(&g_thread, NULL, Process, this);
}

MainWindow::~MainWindow()
{
    bExitThread = true;
    pthread_join(g_thread, NULL);
    mq_close(m_mq);
    mq_unlink(MQNAME);
    delete ui;
}


  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在Linux下,QT可以使用mqueue消息队列实现进程间通信。为了使用消息队列,需要包含头文件#include <mqueue.h>,并在pro文件中添加编译选项LIBS = -lrt。消息队列具有以下特征:可以设置最大消息个数和每个消息的最大字节数,可以向消息队列中写入多条消息,而其他进程读取一条消息后,消息队列就会删除这条消息。 要发送消息到消息队列中,可以使用mq_send函数。该函数的原型是int mq_send(mqd_t mqdes, const char *ptr, size_t len, unsigned int prio)。其中,mqdes是打开消息队列时返回的消息队列描述符,ptr是指向要发送的消息的指针,len是消息的长度,prio是消息的优先级。 在应用中使用消息队列进行进程间通信,可以发现消息队列具有强大的功能。它可以方便地管理线程,实现互斥量和条件变量等功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Qt实现IPC进程间通信-mqueue消息队列](https://blog.csdn.net/weixin_40355471/article/details/113178838)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [进程间通信之深入消息队列的详解](https://download.csdn.net/download/weixin_38517212/14872197)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值