聊聊python里如何用Borg pattern實(shí)現(xiàn)的單例模式
有如下 borg pattern 的實(shí)現(xiàn):
class Borg(object): __shared_state = {} def __init__(self): self.__dict__ = self.__shared_state self.state = 'Init' def __str__(self): return self.state
之前一直看不懂為什么 Borg class 要那樣實(shí)現(xiàn), 后來(lái)學(xué)到兩個(gè)知識(shí)點(diǎn)后發(fā)現(xiàn)原來(lái)這么簡(jiǎn)單明了:
- 關(guān)于 __shared_state:
- 在 __init__(self, ) 外面定義的變量,是屬于這個(gè) class 的,并且由所有的 instance 共享的,而不是單屬于某個(gè)instance; 在 __init__(self, ) 里面定義的變量,只屬于這個(gè) object instance (self) 本身。
- 關(guān)于 __dict__:
- 類(lèi)的靜態(tài)函數(shù)、類(lèi)函數(shù)、普通函數(shù)、全局變量以及一些內(nèi)置的屬性都是放在類(lèi)__dict__里的;對(duì)象的__dict__中存儲(chǔ)了一些self.xxx的一些東西
試著跑一下:
if __name__ == '__main__': rm1 = Borg() rm2 = Borg() rm1.state = 'Idle' rm2.state = 'Running' print('rm1: {0}'.format(rm1)) print('rm2: {0}'.format(rm2)) rm2.state = 'Zombie' print('rm1: {0}'.format(rm1)) print('rm2: {0}'.format(rm2)) print('rm1 id: {0}'.format(id(rm1))) print('rm2 id: {0}'.format(id(rm2))) rm3 = YourBorg() print('rm1: {0}'.format(rm1)) print('rm2: {0}'.format(rm2)) print('rm3: {0}'.format(rm3))
其結(jié)果為:
### OUTPUT ###
# rm1: Running
# rm2: Running
# rm1: Zombie
# rm2: Zombie
# rm1 id: 140732837899224
# rm2 id: 140732837899296
# rm1: Init
# rm2: Init
# rm3: Init
本文代碼來(lái)自: https://github.com/faif/python-patterns/blob/master/patterns/creational/borg.py
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python腳本實(shí)現(xiàn)集群檢測(cè)和管理功能
這篇文章主要介紹了Python腳本實(shí)現(xiàn)集群檢測(cè)和管理功能,本文講解了實(shí)現(xiàn)想法、開(kāi)發(fā)工具選擇、經(jīng)驗(yàn)分享、代碼示例等內(nèi)容,需要的朋友可以參考下2015-03-03Python中等待5秒并暫停執(zhí)行的方法總結(jié)
Python 具有各種功能和庫(kù)來(lái)創(chuàng)建交互式應(yīng)用程序,用戶(hù)可以在其中提供輸入和響應(yīng), 我們可以創(chuàng)建需要暫停應(yīng)用程序執(zhí)行的情況,本文主要和大家分享三個(gè)Python 中等待 5 秒并暫停執(zhí)行的方法,有需要的可以參考下2023-10-10Python中time庫(kù)的使用(日期時(shí)間)
time庫(kù)是python中處理時(shí)間的標(biāo)準(zhǔn)庫(kù),這篇文章主要介紹了Python中time庫(kù)的使用(日期時(shí)間),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02Python?Scala中使用def語(yǔ)句定義方法的詳細(xì)過(guò)程
這篇文章主要介紹了Python?Scala中使用def語(yǔ)句定義方法,Scala的方法是類(lèi)的一部分,而函數(shù)是一個(gè)對(duì)象可以賦值給一個(gè)變量,下面來(lái)講解Scala的方法,需要的朋友可以參考下2022-09-09pandas重置索引標(biāo)簽的實(shí)現(xiàn)示例
在使用Pandas進(jìn)行數(shù)據(jù)處理時(shí),有時(shí)候我們可能會(huì)需要對(duì)數(shù)據(jù)進(jìn)行重置索引的操作,本文主要介紹了pandas重置索引標(biāo)簽的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-04-04Django異步任務(wù)線(xiàn)程池實(shí)現(xiàn)原理
這篇文章主要介紹了Django異步任務(wù)線(xiàn)程池實(shí)現(xiàn)原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12Python2寫(xiě)csv文件中文亂碼問(wèn)題及解決方法
python2最大的坑在于中文編碼問(wèn)題,遇到中文報(bào)錯(cuò)首先加u,再各種encode、decode,這篇文章給大家介紹Python2寫(xiě)csv文件中文亂碼問(wèn)題及解決方法,感興趣的朋友跟隨小編一起看看吧2022-11-11