QT程序中单纯使用共享内存无法实现进程间通信,需要搭配其它的通信手段才能实现进程间通信。相比于管道通信和其它的一些通信手段,共享内存通信的优势是通信速度快,通信传输的数据量大。像管道和一些其它的进程间通信手段单次传输的数据块都很小,而共享内存则可以传输尺寸很大的文件和数据。
一般我建议在windows下共享内存搭配windows事件进行使用,在Linux下面搭配dbus总线通信使用。
下面介绍一下windows平台下共享内存通信的使用方法,Linux下的实现原理相同只需要将windows事件替换成dbus通信事件就行了。
客户端程序
客户端先创建对应的共享内存,然后修改共享内存的内容,修改完毕之后发送固定的windows事件消息通知服务端。
QSharedMemory shared("sharesegment.share");
//对共享内存的内容进行修改
void set_sharesegment_content(QString content)
{
shared.create(256))
if(shared.attach())
{
QString pos_str = "inform-content";
shared.lock();
memcpy((char*)shared.data(),content.toStdString().c_str(),
content.size());
shared.unlock();
//修改内容之后发送windows通知
send_inform_event();
if(shared.isAttached())
{
shared.detach();
}
}
}
void send_inform_event()
{
HANDLE hEvent = OpenEvent(EVENT_ALL_ACCESS, NULL, L"sharememory.changed");
if(hEvent != NULL)
{
SetEvent(hEvent);
}
}
服务端程序
服务端先开辟一个线程,在线程里面监听对应的windows事件消息,当收到对应的事件消息之后,打开对应的共享内存,读取共享内存中的内容,然后根据共享内存中内容执行对应的操作。
#include <QSharedMemory>
#include <Windows.h>
void start_running()
{
QSharedMemory shared("sharesegment.share");
while(true)
{
//监听对应的消息
HANDLE hEvent = CreateEvent(NULL, FALSE, FALSE, L"sharememory.changed");
WaitForSingleObject(hEvent, INFINITE);
ResetEvent(hEvent);
//收到消息之后读取共享内存中内容
if(shared.attach())
{
shared.lock();
QString input_content = QString((char*)shared.data());
if(!input_content.isEmpty())
{
//根据内容执行对应的操作
memset((char*)shared.data(),0x00,64);
}
shared.unlock();
if(shared.isAttached())
{
shared.detach();
}
}
}
}