Qt:实现单例模式

embedded/2024/9/24 16:32:26/

前言

记录一下。

正文

单例模式根据实现方式和应用场景在Qt中可以分为以下几种类型:

1. 懒汉式单例

懒汉式单例在第一次使用时才创建实例,延迟了对象的初始化。懒汉式单例分为线程安全和线程不安全两种实现方式。

  • 线程不安全的懒汉式单例

    • 在第一次调用 getInstance() 时创建实例,未实现线程安全保护,多线程情况下可能导致多个实例被创建。
  • 线程安全的懒汉式单例(最常用)

    • 在第一次调用时创建实例,使用锁机制确保在多线程环境中只创建一个实例。

优点:实例不会过早创建,节省内存。
缺点:在多线程环境下需要额外处理线程安全问题,可能影响性能。

2. 饿汉式单例

饿汉式单例在程序启动时就创建实例,实例的生命周期与程序相同。

  • 实例在类加载时就创建,适合频繁使用的场景。
  • 饿汉式单例的线程安全是由于其在类加载时由编译器自动处理,不需要额外的锁机制。

优点:简单直接,线程安全,适合在启动时需要立即使用的场景。
缺点:无论是否使用该实例,程序启动时就会创建,可能浪费资源。

3. 静态局部变量单例(最简单)

C++11 标准引入了线程安全的静态局部变量初始化机制,可以用于简化单例的实现。在这种方法下不需要显示的管理内存。

  • getInstance() 方法中,使用一个静态局部变量来保存单例对象。C++11 保证了静态局部变量的线程安全初始化。

优点:简单且线程安全,不需要显式加锁。
缺点:C++11 及以上标准才支持。

4. 使用 Qt 的 Q_GLOBAL_STATIC

这是 Qt 提供的一个特殊实现,通过 Q_GLOBAL_STATIC 宏创建一个全局静态对象,自动管理线程安全性。

优点:适合 Qt 程序,线程安全,简化了实现逻辑。
缺点:只能用于 Qt 环境中。

实现

具体实现参考我的其它文章
Qt:懒汉单例(附带单例使用和内存管理)
Qt:饿汉单例(附带单例使用和内存管理)
Qt:静态局部变量实现单例(附带单例使用和内存管理)
Qt:Q_GLOBAL_STATIC实现单例(附带单例使用和内存管理)

小结

如有错误请指正。


http://www.ppmy.cn/embedded/114714.html

相关文章

C++【类和对象】(一)

文章目录 前言1.类的定义1.1类定义格式1.2 访问限定符1.3 类域 2. 实例化2.1 实例化的概念2.2 对象大小 3.this指针结语 前言 在前文我们讲解了C基础语法知识。本文将会讲解C的类和对象。 1.类的定义 1.1类定义格式 class name {};class为定义类的关键字&#x…

深度解码:机器学习与深度学习的界限与交融

目录 一、定义与起源:历史长河中的两条轨迹 二、原理差异:从浅层到深层的跨越 三、代码解析:实战中的机器学习与深度学习 机器学习示例:线性回归 深度学习示例:卷积神经网络(CNN) 四、应用差异:各自领…

解决 Prettier ESLint 错误

解决 Prettier ESLint 错误 在 Vue.js 项目中使用 ESLint 和 Prettier 时,你可能会遇到类似以下的错误: frontend\src\views\dashboard\MobileConfigPanel.vue1:25 error Delete ␍ …

Leetcode面试经典150题-739.每日温度

应读者私信要求,本题协商题目的具体内容 给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高&#xff0…

【C#生态园】深入比较:六款C#数据流处理库对比解析

解密C#数据流处理利器:全面评析六大库 前言 随着信息技术的不断发展,数据流处理已经成为许多软件系统中必不可少的一部分。针对C#和.NET开发者来说,选择合适的数据流处理库可以极大地提高开发效率和系统性能。本文将介绍几个流行的C#数据流…

如何优化前端页面的 AJAX 请求性能并避免冲突

个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119@qq.com] 📱个人微信:15279484656 🌐个人导航网站:www.forff.top 💡座右铭:总有人要赢。为什么不能是我呢? 专栏导…

使用Maven创建一个Java项目并在repository中使用

JDK环境:1.8.0_371 Maven环境 :Apache Maven 3.6.3 配置完成jdk和mvn后,进入到指定文件夹下执行如下语句: mvn archetype:generate -DgroupIdtop.chengrongyu -DartifactIdCyberSpace -DarchetypeArtifactIdmaven-archetype-quic…

【vue2】v-scale-screen大屏自适应组件

第一步&#xff1a;安装 npm install v-scale-screen 或 yarn add v-scale-screen 第二步&#xff1a;main.js中引入 import Vue from vue import VScaleScreen from v-scale-screen Vue.use(VScaleScreen) 第三步&#xff1a;页面使用 <template><v-scale-scree…