线程安全单例:如何正确实现与验证
副标题 / 摘要 单例常见但容易出错,尤其在并发场景。本文给出线程安全的实现思路与注意事项。 目标读者 使用单例的后端工程师 关注并发正确性的开发者 负责核心基础组件的团队 背景 / 动机 单例常用于配置、连接池或缓存管理。 错误实现会导致多实例或竞态问题。 核心概念 单例:全局唯一实例 线程安全:并发访问不破坏一致性 延迟初始化:按需创建实例 实践指南 / 步骤 优先使用语言内建的单例机制 需要懒加载时使用锁或原子操作 避免在构造函数中做重逻辑 对并发访问写压力测试 可运行示例 import threading class Singleton: _instance = None _lock = threading.Lock() def __new__(cls): if cls._instance is None: with cls._lock: if cls._instance is None: cls._instance = super().__new__(cls) return cls._instance if __name__ == "__main__": objs = [] for _ in range(3): objs.append(Singleton()) print(len(set(id(x) for x in objs))) # 1 解释与原理 双重检查锁避免了每次创建都加锁的开销,同时保证并发下只生成一个实例。 关键是“锁内再检查”,避免竞态。 常见问题与注意事项 单例会带来全局状态污染吗? 会,因此应谨慎使用。 ...