【Qt】Qt之進程間通訊(共享內存)【轉】

簡述

上一節中,咱們分享下如何利用Windows消息機制來進行不一樣進程間的通訊。可是有不少侷限性,好比:不能跨平臺,並且必須兩個進程同時存在才能夠,要麼進程A發了消息誰接收呢?ui

下面咱們來分享另一種跨平臺的進行間通訊的方式-Shared Memory(共享內存)。spa

 

 

注意事項

初始化QSharedMemory時,必須指定一個惟一的標識Key,進程的Key必須保持一致。能夠使用setKey來設置。.net

加載進內存

說明

進程A-寫code

分爲下面幾步:blog

  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)); }

原文做者:一去丶二三裏
做者博客:去做者博客空間
相關文章
相關標籤/搜索