- 论坛徽章:
- 0
|
在Python中,万物皆对象。类也是。每个类多有一个自己的类型,而Python提供了一个可以自定义类类型的方式,通过元类可以改变传统意义上类的类型,当然也就改变了类的默认行为。
下面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
#当创建MyClass的实例的时候这个call方法将会被调用参数cls是MyClass
class MyClass:
__metaclass__ = MyMeta
元类MyMeta的__init__方法将会在MyClass这个类被创建的时候就被调用,MyClass将会被当作第一个参数传递给它。
元类的__call__方法将会在创建MyClass实例的时候被调用,同样MyClass将会被当作第一个参数传入。
最后贴一段使用MetaClass来实现的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
执行
ob1 = MyClass()
ob2 = MyClass()
assert ob1 is ob2#不会抛出异常
PS:__new__是干嘛的?
本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/59571/showart_2071977.html |
|