- 主页 > 生活百科 > >
两句话掌握 Python 最难知识点——元类出处( 七 )
class MetaSingleton(type): instance = None def __call__(cls, *args, **kw): """ this is comment """ print 'in call method' if cls.instance is None: # cls.instance = super(MetaSingleton, cls).__call__(*args, **kw) # cls.instance = type.__dict__['__call__'].__get__(cls)(*args, **kw) cls.instance = type.__call__(cls, *args, **kw) print cls.instance return cls.instance class Foo(object): __metaclass__ = MetaSingleton def __init__(self, a, b): self.a = a self.b = b a = Foo(1, 2) b = Foo(3, 4) assert a is b print a.a, a.b, b.a, b.b print type(Foo) print Foo.__call__ 例子很直接,__call__方法里面通过判断是否已经有初始化过的实例,没有就仿照正常未指定元类的情况下调用type的__call__方法(当然这里要么通过super binding要么手动指定cls上下文),生成一个Foo的实例存储和返回出来 。但是有一个注意点是,call方法每次初始化实例对象的时候都会被调用,这也和先前说的控制实例的生成一致: Python (<class '__main__.B'>, <class '__main__.A'>, <type 'object'>) in call method <__main__.Foo object at 0x00000000024BFA90> in call method <__main__.Foo object at 0x00000000024BFA90> 1 2 1 2 <class '__main__.MetaSingleton'> <bound method MetaSingleton.__call__ of <class '__main__.Foo'>> 还有一个需要在意的地方是最后的两行打印日志,Foo类型的元类是Metasingleton(调用new生成类型的时候默认指定元类是第一个参数);Foo的__call__方法是绑定了Foo(MetaSingleton的实例)实例的MetaSingleton的方法,也就是从另外的方面证实每次初始化Foo类型市里的时候,其实是在调用元类中重写的__call__方法 。 元类这个特性大多数情况下确实使用的不多并且需要稍微花点时间来理解,但是需要使用的时候会非常好用,往往能够实现很多优雅的功能,最典型的就是ORM的实现了,只不过会更加的复杂,且pythoning且学习吧,PEACE! 参考资料中的链接里面有有几个实际的例子,本文也是学习其中的内容后配合一些其它一些使用经验以及碰到的问题理而成,希望对大家有用 。【两句话掌握 Python 最难知识点——元类出处】
推荐阅读
-
情感日记文字简单,纯粹,知道自己想要什么,真正的成熟
-
-
央视新闻客户端|霞姐带你追火星Vlog丨揭秘“天问一号”如何在太空保持轨道 如何入环火轨道
-
『军事聊聊聊』最值得入手的是它,奇迹暖暖:联盟梦幻工坊34件套装大起底
-
-
偶尔吃一次榴莲会不会胖 偶尔吃一次榴莲会不会胖一点
-
-
李玉成|85岁马玉琴感冒加重,李玉成却被新欢追到家里,网友:丢人现眼
-
-
红酒酒精度高还是啤酒酒精度高 红酒酒精度比啤酒高吗
-
-
-
#国际之识#患者死亡率竟高达50%,英国重症监护房坚持只接受最严重病人
-
热门美剧|官方计划引入新角色,DC剧《蝙蝠女侠》未来:首季女主退出
-
时尚街拍酱搭|舒适休闲,时髦百搭,简单洁白的运动套装穿搭
-
特朗普金色头发变得花白|特朗普金色头发变得花白引发美国网友关注
-
-
吓人|墨香家族祖传厨艺太吓人,魏无羡是食物终结者,谢怜做饭要人命
-
-
曾令旭|又一个小丁?曾令旭开始投篮,媒体人:想拿身体做赌注强行复出!