您的位置:首页 > 编程语言 > Python开发

python中实现单例的三种方法

2017-07-22 00:00 302 查看

方法一:使用装饰器

装饰器维护一个字典对象instances,缓存了所有单例类,只要单例不存在则创建,已经存在直接返回该实例对象。

Python

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def singleton(cls):
instances = {}

def wrapper(*args, **kwargs):
if cls not in instances:
instances[cls] = cls(*args, **kwargs)
return instances[cls]

return wrapper

@singleton
class Foo(object):
pass

foo1 = Foo()
foo2 = Foo()

print foo1 is foo2

方法二:使用基类

__new__是真正创建实例对象的方法,所以重写基类的__new__方法,以此来保证创建对象的时候只生成一个实例

Python

1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Singleton(object):
def __new__(cls, *args, **kwargs):
if not hasattr(cls, '_instance'):
cls._instance = super(Singleton, cls).__new__(cls, *args,**kwargs)
return cls._instance

class Foo(Singleton):
pass

foo1 = Foo()
foo2 = Foo()

print foo1 is foo2 # True

方法三:使用元类

元类(参考:深刻理解Python中的元类)是用于创建类对象的类,类对象创建实例对象时一定会调用
__call__
方法,因此在调用
__call__
时候保证始终只创建一个实例即可,
type
是python中的一个元类。

Python

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class Singleton(type):
def __call__(cls, *args, **kwargs):
if not hasattr(cls, '_instance'):
cls._instance = super(Singleton, cls).__call__(*args,**kwargs)
return cls._instance

class Foo(object):
__metaclass__ = Singleton

foo1 = Foo()
foo2 = Foo()

print foo1 is foo2 # True
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  装饰器 元类 基类