欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 社会 > 单例模式(Singleton)

单例模式(Singleton)

2024/11/16 7:06:53 来源:https://blog.csdn.net/xiangzun0155/article/details/143803543  浏览:    关键词:单例模式(Singleton)

一、单例模式

1、相关知识:

        内容:保证一个类只有一个实例,并提供一个访问它的全局访问点;其保证了在程序的不同位置都可以且仅可以取到同一个对象实例。

        使用场景:当类只能有一个实例而且用户从多个地方访问同一个类的实例。

        举个例子来说: 比如你开发一款游戏软件,游戏中需要有“场景管理器”这样一种东西,用来管理游戏场景的切换、资源载入、网络连接等等任务。这个管理器需要有多种方法和属性,在代码中很多地方会被调用,且被调用的必须是同一个管理器,否则既容易产生冲突,也会浪费资源。这种情况下,单例模式就是一个很好的实现方法。

例如:

        Python的logger就是一个单例模式,用以日志记录;

        Windows的资源管理器是一个单例模式;

        线程池,数据库连接池等资源池一般也用单例模式;

        网站计数器;

优点:

        1、只有一个实例占用资源,并且只需初始化一次;

        2、对唯一实例的受控访问;

 2、实现方式:

(1)、使用函数装饰器实现单例:

def singleton(cls):_instance = {}def inner():if cls not in _instance:_instance[cls] = cls()return _instance[cls]return inner@singleton
class Cls(object):def __init__(self):passcls1 = Cls()
cls2 = Cls()
print(id(cls1) == id(cls2)) 

# 输出结果:

True

(2)、使用类装饰器实现单例:

class Singleton(object):def __init__(self, cls):self._cls = clsself._instance = {}def __call__(self):if self._cls not in self._instance:self._instance[self._cls] = self._cls()return self._instance[self._cls]@Singleton
class Cls2(object):def __init__(self):passcls1 = Cls2()
cls2 = Cls2()
print(id(cls1) == id(cls2))

# 输出结果:    

True

(3)、使用 new 关键字实现单例模式:

class Single(object):_instance = Nonedef __new__(cls, *args, **kw):if cls._instance is None:cls._instance = object.__new__(cls, *args, **kw)return cls._instancedef __init__(self):passsingle1 = Single()
single2 = Single()
print(id(single1) == id(single2))

# 输出结果:

True

(4)、使用 metaclass 实现单例模式:

class Singleton(type):_instances = {}def __call__(cls, *args, **kwargs):if cls not in cls._instances:cls._instances[cls] = super(Singleton, cls).__call__(*args, **kwargs)return cls._instances[cls]class Cls4(metaclass=Singleton):passcls1 = Cls4()
cls2 = Cls4()
print(id(cls1) == id(cls2))

# 输出结果:

True

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com