当使用这个共享内存类QSharedMemory时,请注意以下平台差异:
Windows:QSharedMemory 不“拥有”共享内存段。当所有具有连接到特定共享内存段的 QSharedMemory 实例的线程或进程已销毁其 QSharedMemory 实例或退出时,Windows 内核会自动释放共享内存段。
Unix:QSharedMemory“拥有”共享内存段。当将 QSharedMemory 实例附加到特定共享内存段的最后一个线程或进程通过销毁其 QSharedMemory 实例与该段分离时,Unix 内核会释放共享内存段。但是如果最后一个线程或进程在没有运行 QSharedMemory 析构函数的情况下崩溃,共享内存段会在崩溃中幸存下来。
HP-UX:每个进程只允许一个连接到共享内存段。这意味着 QSharedMemory 不应跨 HP-UX 中同一进程中的多个线程使用
常用函数:
bool QSharedMemory::create(int size, QSharedMemory::AccessMode mode = ReadWrite)
使用传递给构造函数的键创建大小为size字节的共享内存段,使用setKey () 或使用setNativeKey ()设置key,然后使用给定的访问模式关联到新的共享内存段并返回true。如果返回true,表明创建的同时自动关联到该共享内存(相当于内部已经调用过attach函数)。如果key标识的共享内存段已经存在,则不执行attach操作并false返回。当返回值为 时false,调用error ()来判断发生了哪个错误。
bool QSharedMemory::attach(QSharedMemory::AccessMode mode = ReadWrite)
尝试将进程关联到由传递给构造函数或调用setKey () 或setNativeKey ()的密钥标识的共享内存段。
访问方式默认为ReadWrite。它也可以是ReadOnly。如果附加操作成功则返回true。如果返回false,则调用error ()来判断发生了哪个错误。附加共享内存段后,可以通过调用data ()获得共享内存的指针。
注意:如果没有调用先create函数,直接调用attach函数,attach会返回false.
写数据程序
1.定义QSharedMemory shareMemory,并设置标志名setKey();
2.将共享内存与主进程分离 detach();//如果是当前exe是最后一个使用该memory的进程,那么detach()后,该共享内存的内存地址就被释放了。相当于windows的unmapviewoffile 加 closehandle的结合体 也可以先使用isAttached()判断,如果是确实连接了,再调用detach进行分离。//好像没必要加上detach
3.创建共享内存create(int size, AccessMode mode = ReadWrite), create默认会调用attach函数,让共享内存和当前程序进行关联
4.将共享内存上锁lock();
5.调用data得到共享内存地址,将进程中要共享的数据拷贝到共享内存中,
6.将共享内存解锁unlock();
注意:写完后,坚决不能调用detach(),如果调用detach(),那么共享内存的内存会被释放掉,写入的字节就被删除。 因此一般把detach函数放在该类的析构函数中。
读数据的程序:(读取数据,必须调用attach())
1,定义QSharedMemory shareMemory,并设置共享内存的标志名setKey()注意设置的要与提供内存共享的一方要一样。
2,将共享内存与主进程绑定attach(),使该进程可以访问共享内存的数据;
3,将共享内存上锁lock();
4,调用data得到共享内存地址,从共享内存中取数据;
5,使用完后将共享内存解锁shareMemory.unlock(),
6. 将共享内存与该进程分离shareMemory.detach()
此外还需灵活使用下面的函数:
1. SharedMemoryError error() const;得到错误码, 2. bool isAttached() const;