08-project-shareMemoryWrite

#include "widget.h"
#include "ui_widget.h"
#include <QMessageBox> // 引入QMessageBox头文件,用于展示用户消息对话框,提升用户体验

// Widget类构造函数,负责初始化用户界面及共享内存资源
Widget::Widget(QWidget *parent)
    : QWidget(parent) // 调用基类QWidget的构造函数,传递父窗口指针
    , ui(new Ui::Widget) // 使用new操作符初始化界面对象,采用初始化列表语法
{
    ui->setupUi(this); // 调用ui的setupUi方法来初始化界面元素

    // 创建QSharedMemory对象实例,用于管理共享内存
    shareMemory = new QSharedMemory(this); // 传递this指针作为父对象,便于自动内存管理
    shareMemory->setKey("mengfan"); // 设置共享内存的键,用于唯一标识共享内存段

    // 尝试创建大小为1024字节的共享内存空间
    if (!shareMemory->create(1024))
    {
        // 如果创建失败,使用QMessageBox显示错误信息给用户
        QMessageBox::critical(this, "共享内存错误", "创建共享内存失败。");
        return; // 创建失败则提前终止构造函数执行
    }
}

// Widget类析构函数,负责清理资源,避免内存泄漏
Widget::~Widget()
{
    // 如果共享内存当前正被附加,先执行detach操作断开连接
    if (shareMemory->isAttached())
        shareMemory->detach();

    // 释放QSharedMemory对象占用的资源
    delete shareMemory;

    // 清理用户界面对象
    delete ui;
}

// 槽函数,响应“写入共享内存”按钮的点击事件
void Widget::on_shareMemoryWrite_clicked()
{
    // 确保共享内存已附加到当前进程,否则先执行attach操作
    if (!shareMemory->isAttached())
        shareMemory->attach();

    // 获取文本编辑框中的纯文本内容
    QString data = ui->textEdit->toPlainText();

    // 将文本转换为UTF-8编码的字节数组,以便于存储
    QByteArray dataBytes = data.toUtf8();

    // 检查待写入数据是否超出共享内存大小
    if (dataBytes.size() >= shareMemory->size())
    {
        // 若超出,警告用户并提前返回
        QMessageBox::warning(this, "警告", "输入数据超过共享内存大小。");
        return;
    }

    // 获取共享内存的原始数据指针,并安全地使用memcpy复制数据
    char *p = static_cast<char*>(shareMemory->data());
    std::memcpy(p, dataBytes.constData(), dataBytes.size()); // 执行内存复制
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值