導航:首頁 > 編程語言 > python單例

python單例

發布時間:2022-01-20 21:09:32

python中的import是單例的嗎

可以使用import來實現單例,例如:
# class1.pyclass Singleton(object):
def fun(self):
pass

singleton = Singleton()
# import1.pyfrom mysingleton import singleton

singleton.fun()

意思就是說,直接在 class1.py中將類實例化,然後在import1.py中直接導入實例

❷ Python中的單例模式的幾種實現方式的及優化

單例模式就是 : 1、類的構造函數為private,即外部程序不能通過new關鍵字創建對象的實例 2、類中提供一個private static的 類變數引用 ; 3、單例類中提供靜態方法 定義為 public static 的方法獲取一個類的實例 ; 4、靜態方法返回 類的引用,...

❸ 關於python單例模式求教大佬

因為在__new__函數里給__instance賦了新值_
__new__函數的作用就是,如果__instance還是None,就給cls.__instance新值,然後返回 __instance的值

❹ python類裡面的函數怎麼單例

# mysingleton.py
class My_Singleton(object):
def foo(self):
pass

my_singleton = My_Singleton()

將上面的代碼保存在文件 mysingleton.py 中,然後這樣使用:

from mysingleton import my_singleton

❺ python 單例

類的靜態變數要用classmethod來實現:
import os,sys
class A():
static_data = -1
@classmethod
def set_last(cls, newdata):
temp = cls.static_data
cls.static_data = newdata
return temp

o1=A()
print o1.static_data
A.set_last(12)
print A.static_data
o2=A()
print o2.static_data

輸出:
-1
12
12

❻ 怎麼理解python單例模式

在聊這之前我們首先要明確的是,單例模式在實際中的意義以及在python中具有實現的價值?

當前,相信有很多人支持單例模式,也有不少人反對,尤其是在python中,目前依舊具有很大的爭議性。我們要在評論之前首先要了解單例模式

什麼是單例模式?

顧名思義:就是單個模式

單例模式是一種常見的軟體設置模式,在它的核心結構中只包含一個被稱為單例類的特殊類,通過單例模式可以保證系統中的一個類只有一個實例而且該實例易於外界訪問,從而方便對實例個數的控制並節約系統資源。如果希望在系統中某個對象只能存在一個,單例模式是最好的解決方案。

單例模式的要點有三類

❼ Python如何實現單例模式

有些時候你的項目中難免需要一些全局唯一的對象,這些對象大多是一些工具性的東西,在Python中實現單例模式並不是什麼難事。以下總結幾種方法:
使用類裝飾器
使用裝飾器實現單例類的時候,類本身並不知道自己是單例的,所以寫代碼的人可以不care這個,只要正常寫自己的類的實現就可以,類的單例有裝飾器保證。
def singleton(cls):
instances = {}
def _wrapper(*args, **kwargs):
if cls not in instances:
instances[cls] = cls(*args, **kwargs)
return instances[cls]
return _wrapper
你會發現singleton裝飾器內部使用了一個dict。當然你也可以用其他的方式,不過以下的實現是錯誤的:
def singleton(cls):
_instance = None #外部作用域的引用對於嵌套的內部作用域是只讀的
def _wrapper(*args, **kwargs):
if _instance is None: #解釋器會拋出"UnboundLocalError: ...referenced before assignment"
_instance = cls(*args, **kwargs) #賦值行為使解釋器將"_instance"看作局部變數
return _instance
return _wrapper
使用元類(__metaclass__)和可調用對象(__call__)
Python的對象系統中一些皆對象,類也不例外,可以稱之為」類型對象」,比較繞,但仔細思考也不難:類本身也是一種對象,只不過這種對象很特殊,它表示某一種類型。是對象,那必然是實例化來的,那麼誰實例化後是這種類型對象呢?也就是元類。
Python中,class關鍵字表示定義一個類對象,此時解釋器會按一定規則尋找__metaclass__,如果找到了,就調用對應的元類實現來實例化該類對象;沒找到,就會調用type元類來實例化該類對象。
__call__是Python的魔術方法,Python的面向對象是」Duck type」的,意味著對象的行為可以通過實現協議來實現,可以看作是一種特殊的介面形式。某個類實現了__call__方法意味著該類的對象是可調用的,可以想像函數調用的樣子。再考慮一下foo=Foo()這種實例化的形式,是不是很像啊。結合元類的概念,可以看出,Foo類是單例的,則在調用Foo()的時候每次都返回了同樣的對象。而Foo作為一個類對象是單例的,意味著它的類(即生成它的元類)是實現了__call__方法的。所以可以如下實現:
class Singleton(type):
def __init__(cls, name, bases, attrs):
super(Singleton, cls).__init__(name, bases, attrs)
cls._instance = None
def __call__(cls, *args, **kwargs):
if cls._instance is None
# 以下不要使用'cls._instance = cls(*args, **kwargs)', 防止死循環,
# cls的調用行為已經被當前'__call__'協議攔截了
# 使用super(Singleton, cls).__call__來生成cls的實例
cls._instance = super(Singleton, cls).__call__(*args, **kwargs)
return cls._instance

class Foo(object): #單例類
__metaclass__ = Singleton

>>>a = Foo()
>>>b = Foo()
>>>a is b
>>>True
>>>a.x = 1
>>>b.x
>>>1
使用__new__
__init__不是Python對象的構造方法,__init__只負責初始化實例對象,在調用__init__方法之前,會首先調用__new__方法生成對象,可以認為__new__方法充當了構造方法的角色。所以可以在__new__中加以控制,使得某個類只生成唯一對象。具體實現時可以實現一個父類,重載__new__方法,單例類只需要繼承這個父類就好。
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): #單例類
a = 1

❽ Python如何寫一個多線程下可以使用的單例模式

1。 在數據獲取方面強烈推薦使用TuShare 2。 在我們A股推薦成熟的pyalgotrade 3。測試策略 如:Ricequant 4。恆生的python-恆生量化社區 5。python的量化回測框架 QuantDigger

❾ python創建單例後怎麼刪除

用過濾函數,首先創建一個函數,用過濾函數應用於列表,注意要反轉函數,設置兩個變數,用if…else…語句實現刪除

閱讀全文

與python單例相關的資料

熱點內容
linux轉ansi 瀏覽:736
網站源碼怎麼查 瀏覽:687
高cpu雲伺服器 瀏覽:365
androidwebrtcaecm 瀏覽:981
阿里雲部署java 瀏覽:636
雲是不是就是個大的伺服器 瀏覽:581
如何建立linux日誌管理伺服器 瀏覽:772
悟空頭圖標是什麼APP 瀏覽:555
linuxandroid虛擬機 瀏覽:281
ps李濤pdf 瀏覽:638
linuxfork線程 瀏覽:97
易語言編譯改名 瀏覽:723
阿里伺服器都提供什麼 瀏覽:756
cf打開伺服器接不上怎麼辦 瀏覽:901
linux下more命令 瀏覽:402
des演算法運算位數 瀏覽:375
珠海建行貸款解壓 瀏覽:635
布穀源碼iOS 瀏覽:66
雲存儲節點伺服器是啥 瀏覽:784
壓縮文件可以用pad解壓么 瀏覽:609