0

0

Python如何实现单例模式_多种单例写法对比

冷漠man

冷漠man

发布时间:2026-03-07 19:06:11

|

853人浏览过

|

来源于php中文网

原创

python单例模式有四种主流实现:1.__new__方法(推荐,支持继承、懒加载,线程不安全);2.装饰器(灵活复用,不支持继承);3.模块级单例(最pythonic,线程安全但无法动态控制初始化);4.元类(强大但复杂,适合深度定制)。

python如何实现单例模式_多种单例写法对比

Python 实现单例模式有多种方式,核心目标是:确保一个类只有一个实例,并提供全局访问点。不同写法在可读性、线程安全、兼容性(如继承、装饰器)、以及是否支持懒加载等方面各有侧重。

1. 使用 __new__ 方法(推荐,原生可控)

重写类的 __new__ 是最直接、最符合 Python 习惯的方式。它在实例创建前介入,天然适合控制实例生成逻辑。

说明:通过类变量缓存实例,__new__ 检查是否存在,存在则直接返回,否则调用父类 __new__ 创建新实例。

示例:

立即学习Python免费学习笔记(深入)”;

图酷AI
图酷AI

下载即用!可以免费使用的AI图像处理工具,致力于为用户提供最先进的AI图像处理技术,让图像编辑变得简单高效。

下载
class Singleton:
    _instance = None
<pre class='brush:python;toolbar:false;'>def __new__(cls):
    if cls._instance is None:
        cls._instance = super().__new__(cls)
    return cls._instance
  • ✅ 支持继承(子类需注意重置 _instance 或使用更健壮的实现)
  • ✅ 线程不安全(多线程下可能重复创建;加锁可修复,但影响性能)
  • ✅ 懒加载(首次调用时才创建)
  • ⚠️ 注意:如果类定义了 __init__,每次实例化都会执行——即使返回的是已有实例

2. 使用装饰器(灵活复用,语义清晰)

把单例逻辑抽离为装饰器,可作用于任意类,解耦性好,适合项目中统一管理。

示例:

立即学习Python免费学习笔记(深入)”;

def singleton(cls):
    instances = {}
    def get_instance(*args, **kwargs):
        if cls not in instances:
            instances[cls] = cls(*args, **kwargs)
        return instances[cls]
    return get_instance
<p>@singleton
class Database:
def <strong>init</strong>(self):
print("Database initialized")</p>
  • ✅ 语法简洁,装饰即生效
  • ✅ 天然支持带参初始化(因每次调用仍走 __init__,需额外处理避免重复初始化)
  • ⚠️ 类本身失去“类型直觉”(isinstance(db, Database) 仍成立,但 IDE 可能提示类型丢失)
  • ⚠️ 不支持继承(被装饰后,子类无法自动获得单例行为)

3. 使用模块级单例(最 Pythonic,隐式但高效)

Python 模块天然单例:模块导入一次,对象只初始化一次。这是官方文档也认可的“Python 方式”。

做法:把类实例直接定义在模块中,或直接用模块变量代替类。

示例(config.py):

class Config:
    def __init__(self):
        self.debug = True
<p>config = Config()  # 模块加载时创建,全局唯一</p>
  • ✅ 绝对线程安全(模块加载是原子的)
  • ✅ 零开销、无侵入、易测试
  • ✅ 自动懒加载(首次 import 时触发)
  • ⚠️ 不能动态控制初始化时机(比如依赖环境变量后再创建)
  • ⚠️ 不是“类级别的单例”,而是“模块级别的单例”——如果你需要的是类行为(如继承、方法重载),它不适用

4. 使用元类(强大但复杂,慎用)

元类在类创建阶段介入,适合需要深度定制类行为的场景,但可读性和维护成本高。

示例:

立即学习Python免费学习笔记(深入)”;

class SingletonMeta(type):
    _instances = {}
    def __call__(cls, *args, **kwargs):
        if cls not in cls._instances:
            cls._instances[cls] = super().__call__(*args, **kwargs)
        return cls._instances[cls]
<p>class Logger(metaclass=SingletonMeta):
pass</p>
  • ✅ 对所有子类自动生效(只要指定同一元类)
  • ✅ 可统一拦截所有单例类的实例化过程
  • ⚠️ 元类概念较重,新手难理解,调试困难
  • ⚠️ 与装饰器、__new__ 混用易出冲突

总结来看:日常开发优先考虑 __new__ 写法或模块级单例;需要跨多个类复用逻辑时选装饰器;仅当架构层有强定制需求才用元类。没有绝对“最好”,只有“最合适”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

763

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

376

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

28

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

103

2026.02.06

discuz database error怎么解决
discuz database error怎么解决

discuz database error的解决办法有:1、检查数据库配置;2、确保数据库服务器正在运行;3、检查数据库表状态;4、备份数据;5、清理缓存;6、重新安装Discuz;7、检查服务器资源;8、联系Discuz官方支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2023.11.20

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

28

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

68

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

164

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号