python單例模式

2022-08-17 08:48:18 字數 1835 閱讀 7914

單例模式是日常應用中最廣泛的模式了,其目的就是令到單個程序中只存在乙個類的例項,從而可以實現資料的共享,節省系統開銷,防止io阻塞等等

但是在多程序的應用中,單例模式就實現不了了,例如一些web應用,django,這些,因為會啟動多條程序來監聽http請求,這樣的會通過單例模式是實現不了資料共享的,也就是實現不了單例模式的目的了,這時需要用程序間通訊方法來實現資料共享,當然也可以嘗試使用redis這些nosql資料庫實現資料共享,因為它們的讀取資料較快。

#encoding=utf-8

__author__ = '[email protected]'

classsingleton(object):

def __new__(cls, *args, **kwargs):

if not hasattr(cls,'_the_instance'):

cls._the_instance=object.__new__(cls,*args, **kwargs)

returncls._the_instance

classa(singleton):

print 'init before'

def __init__(self):

print 'i am __init__'

deff(self):

print 'i am f'a=a()

b=a()

a.f()

print 'done'

這裡寫了個singleton的類,通過重新__new__方法,可以查詢當前程序有沒有該類的例項,如果有就返回該例項,如果沒有就新建乙個

例項化兩次a類(實際只例項化了一次)'init before'只會print一次,但是'i am __init__'是會print兩次的,所以不想重複執行的**要放在』init before『的位置

這種實現方法有三個問題

1.併發的時候會有問題,這個可以通過在__new__中**鎖了解決

2.如果子類需要重新__new__函式,那就麻煩了

3.__init__函式會被呼叫多次

由於模組是執行緒安全的,而且乙個模組只會被例項化一次,所以可以通過模組來實現單例

singleton.py

#encoding=utf-8

__author__ = '[email protected]'num =0

defprint_num():

print num

main.py

#encoding=utf-8

__author__ = '[email protected]'

importsingleton

printsingleton.num

singleton.num += 1singleton.print_num()

如果這樣沒有類的特性,可以這樣:

singleton.py

#encoding=utf-8

__author__ = '[email protected]'

classa():

print 'init before'num =0

def __init__(self):

print 'i am __init__'

deff(self):

print 'i am f'a=a()

main.py

#encoding=utf-8

__author__ = '[email protected]'

importsingleton

a=singleton.a

print a.f()

python單例模式繼承 python單例模式

我們可以使用 new 這個特殊方法。該方法可以建立乙個其所在類的子類的物件。更可喜的是,我們的內建 object 基類實現了 new 方法,所以我們只需讓 sing 類繼承 object 類,就可以利用 object 的 new 方法來建立 sing 物件了。classsing object def...

單例模式 python

單例模式 保證乙個類僅有乙個例項,並提供乙個訪問它的全域性訪問點。實現 某個類只有乙個例項 途徑 1 讓乙個全域性變數使得乙個物件被訪問,但是它不能防止外部例項化多個物件。2 讓類自身負責儲存它的唯一例項。這個類可以保證沒有其他例項可以被建立。即單例模式。多執行緒時的單例模式 加鎖 雙重鎖定。餓漢式...

python單例模式

new 在 init 之前被呼叫,用於生成例項物件。利用這個方法和類的屬性的特點可以實現設計模式的單例模式。單例模式是指建立唯一物件,單例模式設計的類只能例項 例項化1個物件。class singleton object instance none def init self pass def ne...