python單例模式練習

2021-09-20 04:18:16 字數 2961 閱讀 6782

簡單複習單例的思想。單例模式

class earth(object):

__instance=none #定義乙個類屬性做判斷

def __new__(cls):

if cls.__instance==none:

#父類的__new__(cls)建立例項

cls.__instance=object.__new__(cls)

return cls.__instance

else:

#返回已有物件的引用

return cls.__instance

def singleton(cls):

_instance = {}

def _singleton(*args, **kargs):

if cls not in _instance:

_instance[cls] = cls(*args, **kargs)

return _instance[cls]

return _singleton

@singleton

class a(object):

a = 1

def __init__(self, x=0):

self.x = x

a1 = a(2)

a2 = a(3)

class singletondecorator(object):

_instance = none

def __init__(self, cls):

self._cls = cls

def __call__(self, *args, **kwargs):

if self._instance is none:

self._instance = self._cls(*args, **kwargs)

return self._instance

@singletondecorator

class singleton(object):

pass

# 示例:

a = singleton()

b = singleton()

# id(a) == id(b)

# 靜態方法

class singleton(object):

_instance = none

@staticmethod

def get_instance():

cls = __class__

if cls._instance is none:

cls._instance = super(cls, cls).__new__(cls)

return cls._instance

# 示例:

a = singleton.get_instance()

b = singleton.get_instance()

# id(a) == id(b)

"""在靜態函式中,既不會傳入 cls 也不會有 self。為了在靜態函式中使用 cls 的同時,

避免硬編碼,可使用內建變數 __class__。

在乙個類的作用域中,__class__ 等於類物件,即:__class__ == singleton。

"""# 類方法

class singleton(object):

_instance = none

@classmethod

def get_instance(cls):

if cls._instance is none:

cls._instance = super().__new__(cls)

return cls._instance

# 示例:

a = singleton.get_instance()

b = singleton.get_instance()

# id(a) == id(b)

class singletonmetaclass(type):

_instance = none

def __call__(self, *args, **kwargs):

if self._instance is none:

self._instance = super().__call__(*args, **kwargs)

return self._instance

class singleton(metaclass=singletonmetaclass):

pass

# 示例:

a = singleton()

b = singleton()

# id(a) == id(b)

一、 什麼時候用靜態方法,什麼時候使用非靜態方法?

既然靜態方法和例項化方式的區分是為了解決模式的問題,如果我們考慮不需要繼承和多型的時候,就可以使用靜態方法,但就算不考慮繼承和多型,就一概使用靜態方法也不是好的程式設計思想。

二、 為什麼使用單例模式而不用靜態方法?

如果乙個方法和他所在類的例項物件無關,那麼它就應該是靜態的,反之他就應該是非靜態的。如果我們確實應該使用非靜態的方法,但是在建立類時又確實只需要維護乙份例項時,就需要用單例模式了。

比如說我們在系統執行時候,就需要載入一些配置和屬性,這些配置和屬性是一定存在了,又是公共的,同時需要在整個生命週期中都存在,所以只需要乙份就行,這個時候如果需要我再需要的時候new乙個,再給他分配值,顯然是浪費記憶體並且再賦值沒什麼意義。

如果不使用機制對視窗物件進行唯一化,將彈出多個視窗,如果這些視窗顯示的內容完全一致,則是重複物件,浪費記憶體資源;

再舉個例子,比如dal層寫好乙個呼叫資料庫表的類,在bll層應用此類時,如果每次都new建立的話需要頻繁的建立和**,而dal層這個類裡又沒有和物件相關的值變數,所以不需要每次都new乙個,這時候就可以用單例模式來建立這個dal例項。

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...