【Qt】Qt之进程间通信(共享内存)

简述

上一节中,我们分享下如何利用Windows消息机制来进行不同进程间的通信。但是有很多局限性,比如:不能跨平台,而且必须两个进程同时存在才可以,要么进程A发了消息谁接收呢?

下面我们来分享另外一种跨平台的进行间通信的方式-Shared Memory(共享内存)。

 

  • 简述
  • 注意事项
  • 加载进内存
    • 说明
    • 实现
  • 从内存中读取
    • 说明
    • 实现

 

注意事项

初始化QSharedMemory时,必须指定一个唯一的标识Key,进程的Key必须保持一致。可以使用setKey来设置。

加载进内存

说明

进程A-写

分为下面几步:

  1. 检测该进程是否连接到共享内存段,如果连接,则将该进程与共享内存段分离。
  2. 从系统足够大的内存中得到一个新的共享内存段。
  3. 锁定该共享内存段,以阻止第二个对话框进程访问,将缓冲区中的图片复制进共享内存段。
  4. 将共享内存段解锁,然后第二个对话框进程就可以访问了。

实现

void Dialog::loadFromFile() { if (sharedMemory.isAttached()) { // 将该进程与共享内存段分离 if (!sharedMemory.detach()) qDebug() << "Unable to detach from shared memory."; } QString fileName = QFileDialog::getOpenFileName(0, QString(), QString(), tr("Images (*.png *.xpm *.jpg)")); QImage image; if (!image.load(fileName)) { qDebug() << "Selected file is not an image, please select another."; return; } // 将数据加载到共享内存中 QBuffer buffer; buffer.open(QBuffer::ReadWrite); QDataStream out(&buffer); out << image; int size = buffer.size(); // 创建共享内存段 if (!sharedMemory.create(size)) { qDebug() << sharedMemory.errorString() << "\n Unable to create shared memory segment."; return; } sharedMemory.lock(); char *to = (char*)sharedMemory.data(); const char *from = buffer.data().data(); memcpy(to, from, qMin(sharedMemory.size(), size)); sharedMemory.unlock(); }

从内存中读取

说明

进程B-读

分为下面几步:

  1. 将该进程与进程A创建的共享内存段绑定
  2. 锁定共享内存段,复制数据到缓冲区,然后写入到QImage中。
  3. 将共享内存段解锁,然后将该进程与共享内存段分离。

实现

void MainWindow::loadFromMemory() { // 将共享内存与该进程绑定 if (!sharedMemory.attach()) { qDebug() << "Unable to attach to shared memory segment."; return; } // 从共享内存中读取数据 QBuffer buffer; QDataStream in(&buffer); QImage image; sharedMemory.lock(); buffer.setData((char*)sharedMemory.constData(), sharedMemory.size()); buffer.open(QBuffer::ReadOnly); in >> image; sharedMemory.unlock(); sharedMemory.detach(); m_pLabel->setPixmap(QPixmap::fromImage(image)); }


原文作者:一去丶二三里
作者博客:去作者博客空间

你可能感兴趣的:(【Qt】Qt之进程间通信(共享内存))