- 論壇徽章:
- 0
|
在Python中,萬物皆對象。類也是。每個類多有一個自己的類型,而Python提供了一個可以自定義類類型的方式,通過元類可以改變傳統(tǒng)意義上類的類型,當然也就改變了類的默認行為。
下面2種方式定要的類是有一定的不同的:
>>>class C(object):pass
>>>class D:pass
>>>type(C)
>>>type(D)
簡單的元類使用:
class MyMeta(type):
def __init__(cls,name,bases,dic):
print cls.__name__#等同于print MyClass.__name__
print name
def __str__(cls): return "Beautiful class '%s'"%cls.__name__
def __call__(cls):pass
#當創(chuàng)建MyClass的實例的時候這個call方法將會被調(diào)用參數(shù)cls是MyClass
class MyClass:
__metaclass__ = MyMeta
元類MyMeta的__init__方法將會在MyClass這個類被創(chuàng)建的時候就被調(diào)用,MyClass將會被當作第一個參數(shù)傳遞給它。
元類的__call__方法將會在創(chuàng)建MyClass實例的時候被調(diào)用,同樣MyClass將會被當作第一個參數(shù)傳入。
最后貼一段使用MetaClass來實現(xiàn)的Singleton模式(woodpecker.org.cn):
class Singleton(type):
"""Singleton Metaclass"""
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
執(zhí)行
ob1 = MyClass()
ob2 = MyClass()
assert ob1 is ob2#不會拋出異常
PS:__new__是干嘛的?
本文來自ChinaUnix博客,如果查看原文請點:http://blog.chinaunix.net/u1/59571/showart_2071977.html |
|