Python元类
来源:互联网 发布:c语言按位与 编辑:程序博客网 时间:2024/04/29 18:03
背后有一大套的理论 !!管它呢!?理论能当饭吃吗?
先知道怎么用再说!
记住:元类就是类的模板——太形象了了呀,霍霍。
我要一大群的类都具有一中特点,我怎么给他们加上呢?模板模板吗,我从这个模板创建一群类不就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的尝试失败了,而这恰恰证明我们成功了。
其实元类用的不多,理解理解。霍霍!!
先知道怎么用再说!
记住:元类就是类的模板——太形象了了呀,霍霍。
我要一大群的类都具有一中特点,我怎么给他们加上呢?模板模板吗,我从这个模板创建一群类不就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的尝试失败了,而这恰恰证明我们成功了。
其实元类用的不多,理解理解。霍霍!!
- Python元类
- Python元类
- Python之元类
- python学习~元类
- python 元类
- python中的元类
- 关于python元类
- python元类分析
- python元类__metaclass__
- python中的元类
- Python中的元类
- Python使用元类
- python 使用元类
- 元类metaclass -- python
- python元类解析
- Python中的元类
- python 元类
- Python元类编程
- 策略模式
- 依赖抽象,不要依赖具体
- Hibernate入门
- 装饰器模式
- 复合设计模式—MVC
- Python元类
- Spring Annotation -- @Autowired, @Qualifier
- Python的不定参数
- Delphi 控件与窗体之间的位置转换问题
- 阻塞队列BlockingQuene及显示锁Lock
- 【iOS-Cocos2d游戏开发之十二】浅析使用C++/C/OC进行iOS游戏混编出现“failed with exit”问题与小结;
- c#正则表达式
- php判断上传的文件是否是图片类型
- 字符串