——————————————————写入部分——————————————————

(本次程序基于控制台程序)

首先 使用共享内存得召唤一下:

#include <QSharedMemory>

然后 声明QSharedMemory类。并且命名为smem

QSharedMemory smem;

由于共享内存没有访问密钥,则不能找到共享的内存。我们给他设置一下访问密钥

QString key,sharedstring;

设置访问密钥

qDebug() << "Please input the shared memory key:"; 
cin >> key;

然后 声明缓冲区和数据流。缓冲区用于转换和保存数据(使用之前要引用这两个库)

QBuffer buffer; //缓冲区 
QDataStream qdsm(&buffer); //数据流

判断输入访问密钥之后,是否附加到共享内存。如果是,则分离

if(smem.isAttached()) smem.detach(); //判断是否已经连接到共享内存块 如果是的话 就先分离

让用户输入共享的数据

qDebug() << "Please input the string to share:"; 
cin >> sharedstring;

以可读可写的方式打开缓冲区

buffer.open(QBuffer::ReadWrite); //设置读取模式

把共享的字符串输入到数据流

qdsm << sharedstring; //输入共享字符串到数据流

输入到数据流之后 会影响到缓冲区。缓冲区就会得到数据的大小

int size = buffer.size(); //获得字节大小

让共享内存创建一段内存空间,空间大小为缓冲区数据大小。并且检测是否创建成功

if(!smem.create(size)) //检测共享内存段是否创建成功 

qDebug() << "Could not create sharing memory"; 
return a.exec(); 
}

如果创建成功后。为了让程序做读写操作,不让其他的程序影响。我们就先锁上共享内存

smem.lock(); //锁定共享内存

我们先分别获取创建后共享内存的数据的指针和要共享的字符串的数据的指针

char * to = (char *)smem.data(); //共享内存的数据 
const char * from = buffer.data().data(); //被共享内存的数据

利用内存拷贝函数(memcpy),把要共享的数据拷贝到共享数据的空间里。拷贝的数据大小是两者中小的那位。哪位小就是要共享的数据的大小(没有证实)

memcpy(to,from,qMin(smem.size(),size)); //把要共享的内存拷贝到被共享的内存

解锁共享内存空间。使其能够被其他程序访问

smem.unlock(); //把共享内存解锁

——————————————————读取部分——————————————————

照样不误的引用上一部分的头文件……

照常不忘的声明共享内存

QSharedMemory sharemem;

声明共享内存的密钥和读出来的字符串

QString key,readstring;

声明缓冲区

QBuffer buffer;

声明数据流

QDataStream out(&buffer);

让用户输入共享内存的密钥

qDebug() << "Please input the shared memory key:"; 
cin >> key;

设置共享内存的访问密钥。使其能够找到指定共享内存

sharemem.setKey(key);

找到指定的共享内存后关联此内存 (此处可以理解为:去某人的家要东西)

sharemem.attach();

锁上共享内存。(此处可以理解为:关上门,不允许其他人进来)

sharemem.lock();

用缓冲区得到共享内存关联后得到的数据和数据大小

buffer.setData((char *)sharemem.constData(),sharemem.size());

打开缓冲区进行访问

buffer.open(QBuffer::ReadOnly);

使用数据流从缓冲区获得共享内存的数据,然后输出到字符串中

out >> readstring;

解锁共享内存空间 (此处可以理解为:开门,允许其他人进来)

sharemem.unlock();

与共享内存空间分离 (此处可以理解为:我走了,我从家里出去了)

sharemem.detach();

qt 共享内存(QSharedMemory)的更多相关文章

  1. qt 共享内存 单例

        QT 进程间通信之古老的方法(内存共享)     让QT只运行一个实例     以上两篇文章中分别讲述了QSharedMemory的不同作用,第一篇讲了进程间通信,第二篇讲述了怎么让应用程序只 ...

  2. Qt之进程间通信(共享内存)

    简述 上一节中,我们分享下如何利用Windows消息机制来进行不同进程间的通信.但是有很多局限性,比如:不能跨平台,而且必须两个进程同时存在才可以,要么进程A发了消息谁接收呢? 下面我们来分享另外一种 ...

  3. QSharedMemory共享内存实现进程间通讯(IPC)及禁止程序多开

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QSharedMemory共享内存实现进程间通讯(IPC)及禁止程序多开     本文地址:h ...

  4. 【Qt】Qt之进程间通信(共享内存)【转】

    简述 上一节中,我们分享下如何利用Windows消息机制来进行不同进程间的通信.但是有很多局限性,比如:不能跨平台,而且必须两个进程同时存在才可以,要么进程A发了消息谁接收呢? 下面我们来分享另外一种 ...

  5. linux后台查看共享内存和消息队列的命令

    ipcs ipcs -q : 显示所有的消息队列 ipcs -qt : 显示消息队列的创建时间,发送和接收最后一条消息的时间 ipcs -qp: 显示往消息队列中放消息和从消息队列中取消息的进程ID ...

  6. boost进程间通信经常使用开发一篇全(消息队列,共享内存,信号)

    本文概要: 敏捷开发大家想必知道并且评价甚高,缩短开发周期,提高开发质量.将大project独立为不同的小app开发,整个开发过程,程序可用可測,所以提高了总体的质量.基于这样的开发模式和开发理念,进 ...

  7. Linux 共享内存详解一

    共享内存段被多个进程附加的时候,如果不是所有进程都已经调用shmdt,那么删除该共享内存段时,会出现一个临时的不完整的共享内存段(key值是0),无法彻底删除.只有当所有进程都调用shmdt,这个临时 ...

  8. PHP进程通信基础——信号量+共享内存通信

    PHP进程通信基础--信号量+共享内存通信 由于进程之间谁先执行并不确定,这取决于内核的进程调度算法,其中比较复杂.由此有可能多进程在相同的时间内同时访问共享内存,从而造成不可预料的错误.信号量这个名 ...

  9. C++ 共享内存 函数封装

    #pragma once #include <string> #include <wtypes.h> #include <map> using namespace ...

随机推荐

  1. Oracle系列之函数

    涉及到表的处理请参看原表结构与数据  Oracle建表插数据等等 如何调用该过程 call function_name(参数值1,参数值2); 创建function来查询某个雇员的工资 create ...

  2. [NYOJ 43] 24 Point game

    24 Point game 时间限制:3000 ms  |  内存限制:65535 KB 难度:5   描述 There is a game which is called 24 Point game ...

  3. 关于开源框架GPUImage 的简单说明

    GPUImage是一个非常棒的图像处理的开源库,里面提供了非常非常多的滤镜效果来加工图片. 不过就是因为太多效果了,而且对于程序员来说,那么多效果并不清楚知道要用那一个.于是我就使用提供的默认值,加上 ...

  4. Tomcat工作原理详解

    一.Tomcat背景 自从JSP发布之后,推出了各式各样的JSP引擎.Apache Group在完成GNUJSP1.0的开发以后,开始考虑在SUN的JSWDK基础上开发一个可以直接提供Web服务的JS ...

  5. 浅谈Xcode5和Xcode7在系统创建的文件夹和文件中的区别

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  6. HTML5/CSS3动画应用

    http://www.html5tricks.com/cool-html5-css3-animation.html

  7. [综述]领域特定语言(Domain-Specific Language)的概念和意义

    领域特定语言(Domain Specific Language, DSL)是一种为解决特定领域问题而对某个特定领域操作和概念进行抽象的语言.领域特定语言只是针对某个特定的领域,这点与通用编程语言(Ge ...

  8. 使用Visual Studio 2013编写可维护的本地可视化(natvis)

    在Visual Studio 2012中,我们介绍了创建可视化使用原生类型的能力natvis文件. Visual Studio 2013中包含了一些改进,使其更容易编写可视化的类,在内部利用收集来存储 ...

  9. Esper系列(九)NamedWindow语法create、Insert、select

    功能:用于存储一种或多种类型的事件的集合,并能对所存储的事件进行增删改查操作. CreateNameWindow 根据已有的数据源构造 格式: 1  [context context_name]  2 ...

  10. A Tour of Go Struct Literals

    A struct literal denotes a newly allocated struct value by listing the values of its fields. You can ...