本文实例为大家分享了python单例模式的具体代码,供大家参考,具体内容如下
多次实例化的结果指向同一个实例
单例模式实现方式
方式一:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
import settings
class MySQL:
__instance = None
def __init__( self , ip, port):
self .ip = ip
self .port = port
@classmethod
def from_conf( cls ):
if cls .__instance is None :
cls .__instance = cls (settings.IP,settings.PORT)
return cls .__instance
obj1 = MySQL.from_conf()
obj2 = MySQL.from_conf()
obj3 = MySQL.from_conf()
print (obj1)
print (obj2)
print (obj3)
|
方式二:
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
|
import settings
def singleton( cls ):
_instance = cls (settings.IP, settings.PORT)
def wrapper( * args, * * kwargs):
if args or kwargs:
obj = cls ( * args, * * kwargs)
return obj
return _instance
return wrapper
@singleton
class MySQL:
def __init__( self , ip, port):
self .ip = ip
self .port = port
obj1 = MySQL()
obj2 = MySQL()
obj3 = MySQL()
print (obj1)
print (obj2)
print (obj3)
|
方式三:
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
|
import settings
class Mymeta( type ):
def __init__( self , class_name, class_bases, class_dic):
self .__instance = self (settings.IP, settings.PORT)
def __call__( self , * args, * * kwargs):
if args or kwargs:
obj = self .__new__( self )
self .__init__(obj, * args, * * kwargs)
return obj
else :
return self .__instance
class MySQL(metaclass = Mymeta):
def __init__( self , ip, port):
self .ip = ip
self .port = port
obj1 = MySQL()
obj2 = MySQL()
obj3 = MySQL()
print (obj1)
print (obj2)
print (obj3)
|
方式四:
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
|
def f1():
from singleton import instance
print (instance)
def f2():
from singleton import instance,MySQL
print (instance)
obj = MySQL( '1.1.1.1' , '3389' )
print (obj)
f1()
f2()
singleton.py文件里内容:
import settings
class MySQL:
print ( 'run...' )
def __init__( self , ip, port):
self .ip = ip
self .port = port
instance = MySQL(settings.IP, settings.PORT)
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/hades0607/archive/2018/08/28/9548684.html