进程间通信(IPC)之共享内存(SharedMemory)(c++ qt c#)

9 篇文章 2 订阅
7 篇文章 0 订阅
这篇博客介绍了不同编程语言和框架如C++、C#及Qt之间的进程间通信(IPC)实现。通过示例代码展示了如何创建和访问共享内存,实现C++进程之间的通信,C#进程之间的通信,以及Qt进程之间的通信。同时,提到了C++和C#进程间的通信方法,但指出Qt与C#进程间通信的不适用性。
摘要由CSDN通过智能技术生成

1.c++进程之间

#include <stdafx.h>
#include <windows.h>
#include <iostream>

#define BUF_SIZE 4096
using namespace std;

void raedSharedMemCpp()
{
    LPVOID pBuffer;
    HANDLE hMap = OpenFileMapping(FILE_MAP_ALL_ACCESS,0,L"global_shared_memory_cpp");
    if(NULL == hMap)
    {
        DWORD err= ::GetLastError();
        cout << "打开内存失败...." << err << endl;
    }
    else
    {
        while(true)
        {
            pBuffer = MapViewOfFile(hMap, FILE_MAP_ALL_ACCESS,0,0,0);
            char buf[BUF_SIZE] = {0};
            strcpy_s(buf, (char*)pBuffer);
            cout << "读取内存:" << buf << endl;
            Sleep(100);
        }
    }
}

void writeSharedMemCpp()
{
    char buf[] = "write hello by cpp SharedMem";
    HANDLE hMap = CreateFileMapping(INVALID_HANDLE_VALUE,                     
        NULL,
        PAGE_READWRITE,
        0,
        BUF_SIZE,
        L"global_shared_memory_cpp");
    
    //获取共享内存指针
    LPVOID lpBase = MapViewOfFile(hMap, FILE_MAP_ALL_ACCESS,0,0,BUF_SIZE);
    strcpy((char*)lpBase, buf);
    Sleep(20000);

    UnmapViewOfFile(lpBase); // 解除文件映射
    CloseHandle(hMap);

    cout << "write sharedMemCpp end" << endl;

    return;
}

2.c#进程之间

#using System;
#using System.Runtime.InteropServices;
#using System.IO.MemoryMappedFiles;
#include System.Collections.Generic;
#using System.Diagnostics;

namespace ColsoleAppCsharp
{
    pulbic partial class SharedMemory
    {
        public static void WriteSharedMemCs()
        {
            int size = 1024;
            MemoryMappedFile shardMemory =                 
                 MemoryMappedFile.CreateOrOpen("global_share_memory_Cs",size);
            System.Threading.Thread.Sleep(30);
            var stream = sharedMemory.CreateViewStream(0,size);
            string value = "write by CSharp content";
            byte[] data = System.Text.Encoding.UTF8.GEtBytes(value);
            stream.Write(data, 0, data.Length);
            stream.Dispose();
        }

        public static void readSharedMemCs()
        {
            int size = 1024;
            MemoryMappedFile mmf = 
                 MemoryMappedFile.OpenExisting("global_share_memory_Cs");
            using(var mmfStream =         
                 mmf.CreateViewStream(0,size,MemoryMappedFileAccess.ReadWrite))
            {
                byte[] buffer = new byte[128];
                int nLen = 0;
                StringBuilder sb = new StringBuilder();
                do
                {
                    nLen = mmfStream.Read(buffer, 0, 128);
                    sb.AppendLine(System.Text.ASCIIEncoding.GetString(buffer));
                }while(nLen>0)
                    
                Console.WriteLine("读取内        
                     存:"+sb.ToString().Replace("\0",null).TrimEnd());
            }
        }
    }
}

3.qt进程之间

#include <QSharedMemory>
#include <QDebug>
#include <QByteArray>

using namespace std;
using namespace std::chrono;

void readSharedMemQt()
{
    QSharedMemory sharedMemory;
    sharedMemory.setKey("global_share_memory_Qt");
    QString tmpStr("");
    
    while(true)
    {
        char c;
        
        // 绑定进程
        if(!sharedMemory.isAttached())
        {
            if(!sharedMemory.attach())
            {
                qDebug() << sharedMemory.errorString();
            }
            else
            {
                sharedMemory.lock();
                QByteArray arr((char*)sharedMemory.data(),sharedMemory.size());
                tmpStr = arr;
                sharedMemory.unlock();
                sharedMemory.detach();
                
                std::this_thread::sleep_for(milliseconds(30));
            }
        }
    }
}

void writeSharedMemQt()
{
    QSharedMemory sharedMemory;
    sharedMemory.setKey("global_share_memory_Qt");
    if(sharedMemory.isAttched())
    {
        qDebug() << "detach" << sharedMemory.detach();
    }

    QByteArray arr = "write by Qt shared Mem";
    int len = arr.length();
    if(!sharedMemory.create(len))
    {
        qDebug() << sharedMemory.errorString();
    }

    sharedMemory.lock();
    char* dest = reinterpret_cast<char*>(sharedMemory.data());
    for(int i = 0; i < len; i++)
    {
        dest[i] = arr[i];
    }
    sharedMemory.unlock();
}

4.c++进程与c#进程之间,读写共享内存。

参见《1.c++进程之间》和《2.c#进程之间》,一边读,另一边写就行了。

5.qt进程与c#进程之间,不行。

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用QT共享内存方式进行进程间通信的例程: 首先,在发送进程中,我们需要创建一个共享内存对象,并将数据写入共享内存中: ```cpp #include <QSharedMemory> #include <QBuffer> // 创建共享内存对象 QSharedMemory sharedMemory("my_shared_memory"); // 打开共享内存 if (!sharedMemory.create(sizeof(int))) { qDebug() << "Cannot create shared memory segment."; return; } // 将数据写入共享内存中 QBuffer buffer; QDataStream out(&buffer); out << static_cast<int>(42); const QByteArray data = buffer.data(); memcpy(sharedMemory.data(), data.constData(), qMin(sharedMemory.size(), data.size())); ``` 然后,在接收进程中,我们需要打开共享内存,并从共享内存中读取数据: ```cpp #include <QSharedMemory> #include <QBuffer> // 创建共享内存对象 QSharedMemory sharedMemory("my_shared_memory"); // 打开共享内存 if (!sharedMemory.attach()) { qDebug() << "Cannot attach shared memory segment."; return; } // 从共享内存中读取数据 QBuffer buffer; const char *data = static_cast<const char*>(sharedMemory.constData()); buffer.setData(data, sharedMemory.size()); int value; QDataStream in(&buffer); in >> value; qDebug() << "Received value:" << value; ``` 以上例程中,我们创建了一个名为“my_shared_memory”的共享内存对象,然后在发送进程中将一个整数值写入共享内存中,接着在接收进程中打开共享内存,并从中读取整数值并输出。 需要注意的是,共享内存方式的进程间通信需要保证多个进程都能够访问同一个共享内存对象,因此需要使用相同的共享内存名称。此外,需要在访问共享内存时进行同步控制,以避免数据竞争问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值