Chinaunix首页 | 论坛 | 博客
  • 博客访问: 560011
  • 博文数量: 166
  • 博客积分: 4038
  • 博客等级: 上校
  • 技术积分: 1115
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-14 23:29
文章分类

全部博文(166)

文章存档

2010年(12)

2009年(126)

2008年(28)

分类: Python/Ruby

2009-10-16 16:24:31

在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__是干嘛的?
阅读(1033) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~