当前位置: 首页 > news >正文

QtApplets-实现应用程序单例模式,防止重复运行

头图

QtApplets-实现应用程序单例模式,防止重复运行


文章目录

  • QtApplets-实现应用程序单例模式,防止重复运行
    • 摘要
    • 引言
    • 实现原理
    • 核心代码实现
      • 头文件定义
      • 实现文件
    • 使用方法
    • 技术要点解析
      • 1. 文件锁机制
      • 2. 进程 ID 管理
      • 3. Windows 互斥量
      • 4. 跨平台兼容
    • 注意事项
    • 实际应用场景
    • ☞ 源码

关键字: Qt单例模式QLockFile进程管理跨平台

摘要

本文将详细介绍如何在 Qt 应用程序中实现单例模式,确保应用程序只能运行一个实例。通过文件锁、进程 ID 和互斥量等多种机制,实现了一个健壮的单例模式解决方案。

image-20250417145029947

引言

在开发桌面应用程序时,我们经常需要确保应用程序只能运行一个实例。比如,当用户尝试重复启动程序时,我们应该提示用户程序已经在运行,而不是启动新的实例。本文将介绍如何在 Qt 中实现这一功能。

实现原理

我们的单例模式实现采用了多重保护机制:

  1. 文件锁机制:使用 QLockFile 创建锁文件
  2. 进程 ID 记录:保存当前运行实例的进程 ID
  3. 互斥量机制:Windows 系统下额外使用系统互斥量
  4. 进程存活检测:验证已存在进程是否真实运行

核心代码实现

头文件定义

class SingleInstance : public QObject {Q_OBJECT
public:explicit SingleInstance(const QString& appKey, QObject* parent = nullptr);~SingleInstance();bool isRunning();  // 返回true表示已有实例运行void killExisting(); // 强制终止已有实例private:bool isProcessAlive(qint64 pid);qint64 readPidFromFile();void writeCurrentPid();void cleanup();QString m_lockFilePath;QString m_pidFilePath;#ifdef Q_OS_WINHANDLE m_hMutex = nullptr;
#endif
};

实现文件

SingleInstance::SingleInstance(const QString& appKey, QObject* parent): QObject(parent)
{// 构造唯一文件路径QString tempDir = QStandardPaths::writableLocation(QStandardPaths::TempLocation);m_lockFilePath = tempDir + "/" + appKey + ".lock";m_pidFilePath = tempDir + "/" + appKey + ".pid";#ifdef Q_OS_WIN// Windows额外使用互斥量m_hMutex = CreateMutexW(NULL, TRUE, (L"Global\\" + appKey.toStdWString()).c_str());if (GetLastError() == ERROR_ALREADY_EXISTS) {ReleaseMutex(m_hMutex);CloseHandle(m_hMutex);m_hMutex = nullptr;}
#endif
}

使用方法

在应用程序的 main.cpp 中,我们只需要添加几行代码即可实现单例模式:

int main(int argc, char *argv[])
{// 使用应用名称作为唯一标识SingleInstance guard("YourAppName_Company");if (guard.isRunning()) {QMessageBox::warning(nullptr, "警告", "程序已在运行中");guard.killExisting(); // 可选:强制终止已有实例}QApplication a(argc, argv);Widget w;w.show();return a.exec();
}

技术要点解析

1. 文件锁机制

使用 QLockFile 创建锁文件,这是最基础的检测机制。如果无法创建锁文件,说明可能有其他实例正在运行。

2. 进程 ID 管理

通过 PID 文件记录当前运行实例的进程 ID,并在检测时验证该进程是否真实存在。这可以避免因程序异常退出导致的锁文件残留问题。

3. Windows 互斥量

在 Windows 系统下,额外使用系统互斥量机制,提供更可靠的进程间通信方式。

4. 跨平台兼容

代码通过条件编译(#ifdef Q_OS_WIN)实现了跨平台兼容,同时支持 Windows 和 Unix-like 系统。

注意事项

  1. 清理机制:程序退出时会自动清理锁文件和 PID 文件
  2. 异常处理:包含了进程异常退出的处理机制
  3. 资源释放:确保所有系统资源(如互斥量)都能正确释放
  4. 性能考虑:检测过程快速,不会影响程序启动速度

实际应用场景

  1. 主程序保护:防止用户重复启动应用程序
  2. 资源独占:确保某些资源只被一个实例访问
  3. 配置管理:避免多个实例同时修改配置文件
  4. 系统托盘:配合系统托盘实现更好的用户体验

☞ 源码

源码链接:GitHub仓库自取

使用方法:☟☟☟


博客签名2021

相关文章:

  • 2025年Q2(流动式)起重机司机考试题
  • 【Windows本地部署n8n工作流自动平台结合内网穿透远程在线访问】
  • Ubuntu利用docker搭建Java相关环境记录(二)
  • Vision Transformer项目分析与介绍
  • 压缩包网页预览(zip-html-preview)
  • Apache Atlas构建安装(Linux)
  • Python 深度学习 第8章 计算机视觉中的深度学习 - 卷积神经网络使用实例
  • YOLO训练多评价指标曲线画图
  • 【2025“华中杯”大学生数学建模挑战赛】选题分析 A题 详细解题思路
  • k8s报错kubelet.go:2461] “Error getting node“ err=“node \“k8s-master\“ not found“
  • 【秣厉科技】LabVIEW工具包——OpenCV 教程(20):拾遗 - imgproc 基础操作(下)
  • Python实例题:Python自动化开发-考勤处理
  • iptables防火墙
  • 深入浅出 Redis:核心数据结构解析与应用场景Redis 数据结构
  • 简述Apache RocketMQ
  • R语言简介与下载安装
  • 面试题之高频面试题
  • 扩展欧几里得算法【Exgcd】的内容与题目应用
  • MySQL-数据查询(CASE练习)-01
  • Vue 组件化开发
  • 特写|银耳种植“北移”到沧州盐山,村民入伙可年增收4万元
  • 国际乒联主席索林:洛杉矶奥运会增设混团是里程碑事件
  • 上百家单位展示AI+教育的实践与成果,上海教育博览会开幕
  • 嫩黑线货物列车脱轨致1名路外人员死亡,3人被采取刑事强制措施
  • 央视起底“字画竞拍”网络传销案:涉案44亿元,受害者众多
  • 舱位已排到月底,跨境电商忙补货!美线订单大增面临爆舱,6月运价或翻倍