#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()); // 执行内存复制
}
08-project-shareMemoryWrite
于 2024-04-23 20:22:20 首次发布