-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsingleton.py
More file actions
61 lines (45 loc) · 1.35 KB
/
singleton.py
File metadata and controls
61 lines (45 loc) · 1.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
python_pattern.examples.singleton
~~~~~~~~~~~
单例模式
保证一个类仅有一个实 ,并提供一个访问它的全局访问点。
:copyright: (c) 2017 by the yinyi.
:license: BSD, see LICENSE for more details.
"""
# http://stackoverflow.com/questions/6760685/creating-a-singleton-in-python
class BaseClass:
pass
# 装饰器实现
def singleton(class_):
instances = {}
def getinstance(*args, **kwargs):
if class_ not in instances:
instances[class_] = class_(*args, **kwargs)
return instances[class_]
return getinstance
@singleton
class MyClass(BaseClass):
pass
class Singleton(object):
_instance = None
def __new__(class_, *args, **kwargs):
if not isinstance(class_._instance, class_):
class_._instance = object.__new__(class_, *args, **kwargs)
return class_._instance
class MyClass(Singleton, BaseClass):
pass
# 元类实现
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]
# Python2
class MyClass(BaseClass):
__metaclass__ = Singleton
# Python3
class MyClass(BaseClass, metaclass=Singleton):
pass