我要一大群的類都具有一中特點,我怎麼給他們加上呢?模板模板嗎,我從這個模板建立一群類不就OK了?那就需要元類了。霍霍》
定義一個元類(就所一個類的模板!莫多想,還要記住這是類層級的,不是對象層級的!): 複製代碼 代碼如下:class MyMeta(type):
def __init__(cls,name,bases,dic):
print cls.__name__
print name
def __str__(cls):return 'Beautiful class %s'%cls.__name__
這是個什麼東西?哈,這是個元類。是個類的模板。
它要用在哪裡?它要用在一個類裡,作為這個類的模板。
起的什麼作用?模板,就是提供一些共同的特徵。
這個類提供了什麼樣的特徵?兩個特徵,1。類定義後列印類的名字(__init__)。2。列印類的格式(__str__)。
到底回怎麼工作,開啟的你的解譯器,輸入以上的代碼,上路:
輸入:
class MyClass(object):
__metaclass__ = MyMeta
斷行符號結束類的定義時,輸出:
MyClass
MyClass
明白了吧,霍霍!事實證明它確實是初始化一個類,而不是一個對象!!!!!這個是第一個特徵。
第二個:
輸入:
print MyClass
輸出:
Beautiful class MyClass
啊哈,恰如其分,如我們所預料的那樣!!!!!!!!當然你可以任意個人化你的類!!
####################################################################################
下面我們來實現一個Singleton模式(來自啄木鳥社區):
Singleton元類: 複製代碼 代碼如下:class Singleton(type):
def __init__(cls,name,bases,dic):
super(Singleton,cls).__init__(name,bases,dic)
cls.instance = None
def __call__(cls,*args,**kwargs):
if cls.instance is None:
cls.instance = super(Singleton,cls).__call__(*args,**kwargs)
return cls.instance
非常簡單的一個設計模式,相信你能明白是怎麼回事! 複製代碼 代碼如下:class MyClass(object):
__metaclass__ = Singleton
def __init__(self,arg):
self.arg = arg
使用了Singleton元類的類。
是不是只能有一個執行個體呢??那隻能看看了,鄧爺爺說的好:實踐是檢驗真理的唯一標準。——精華!! 複製代碼 代碼如下:>>> my1 = MyClass("hello")
>>> my2 = MyClass("world")
>>> my1 is my2
True
>>> my1.arg
'hello'
>>> my2.arg
'hello'
我們建立my2的嘗試失敗了,而這恰恰證明我們成功了。
其實元類用的不多,理解理解。霍霍!!