QT之QSharedMemory 详解 进程间通信

QSharedMemory的几个重要接口:
setKey(),这是标记共享内存的一个标识符,
在整个操作系统的共享内存中,用这个key去标识它,唯一标识。

create(),创建共享内存,向os申请内存空间,
如果不创建,调用attach()会失败,
在create()的时候,需要制定共享内存的大小,即字节数,
跟windows的CreateFileMapping()一样,都是需要在create()的时候指定,而且大小是固定的,

从共享内存读取数据的时候,必须要先绑定,写入数据不需要attach(),
attach()函数,在workstation.exe进程中,调用该共享内存的attach()函数,
注意是,将该exe绑定到该共享内存中,
如果要读取某个共享内存,必须要想将exe绑定到共享内存中,只有绑定成功,才能读取,

bool QSharedMemory::detach ()
一定要注意这个函数,系统会自动释放该共享内存,导致其data()返回为空,
detach()后,虽然该块共享内存的地址为null,但是它的key还是存在的,因此,可以继续调用create(),重新申请内存,然后就可以继续使用了。

详细使用过程:
向共享内存中提供数据的一方:

写入数据的顺序,最后是先调用一次detach(),然后调用create()重新申请内存。此时detach()实际上是清除共享内存中数据的作用,
1,定义QSharedMemory shareMemory,并设置标志名shareMemory.setKey();//告诉os,我要使用这块memory,
2,将共享内存与主进程分离 shareMemory.detach();//如果是当前exe是最后一个使用该memory的进程,那么detach()后,该共享内存的内存地址就被os释放了,即data()返回null。
但是key还在,还可以使用后面的create()再重新向os申请内存,
3,创建共享内存 shareMemory.create();//向os申请内存
4,将共享内存上锁shareMemory.lock();
5,将进程中要共享的数据拷贝到共享内存中;
6,将共享内存解锁shareMemory.unlock();
写完后,坚决不能调用detach(),如果调用detach(),那么共享内存的内存会被os释放掉,写入的字节就被删除,

从共享内存中取数据的一方:(读取数据,必须调用attach())
1,定义QSharedMemory shareMemory,并设置共享内存的标志名shareMemory.setKey()注意设置的要与提供内存共享的一方要一样。
2,将共享内存上锁shareMemory.lock();
3,将共享内存与主进程绑定shareMemory.attach(),使该进程可以访问共享内存的数据;
4,从共享内存中取数据;
5,使用完后将共享内存解锁shareMemory.unlock(),另外将共享内存与该进程分离shareMemory.detach();

实现一个共享内存数据交互的线程类,线程的run函数如下:
void run()
{
    QSharedMemory   sharedMem;
    sharedMem.setKey(m_sharedMemName);
    bool res = sharedMem.attach(QSharedMemory::ReadOnly);
    if (!res) {
        return;
    }

    while (!m_requestStop) {
        sharedMem.lock();
        char *memData = (char*)sharedMem.data();
        memcpy((void*)&vi, memData, headerSize);

        sharedMem.unlock();
        //进行业务数据处理
        //to do...

        sharedMem.unlock();
    }

    sharedMem.detach();
}


 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值