深刻理解Python中的元类(metaclass)

深刻理解Python中的元类(metaclass)
PEP 3115 – Metaclasses in Python 3000

第一篇文章中我执行后有错误的代码是这一段:

def upper_attr(future_class_name, future_class_parents, future_class_attr):
    '''返回一个类对象,将属性都转为大写形式'''
    #  选择所有不以'__'开头的属性
    attrs = ((name, value) for name, value in future_class_attr.items() \
             if not name.startswith('__'))
    # 将它们转为大写形式
    uppercase_attr = dict((name.upper(), value) for name, value in attrs)
    # 通过'type'来做类对象的创建
    return type(future_class_name, future_class_parents, uppercase_attr)

__metaclass__ = upper_attr  #  这会作用到这个模块中的所有类

class Foo(object):
    #__metaclass__=upper_attr
    # 我们也可以只在这里定义__metaclass__,这样就只会作用于这个类中
    bar = 'bip'

print hasattr(Foo, 'bar')
# 输出: False
print  hasattr(Foo, 'BAR')
# 输出:True

f = Foo()
print f.BAR

注意python3中使用metaclass的语法如下:

class Foo(object,metaclass=upper_attr):
    bar = 'bip'

另外在python2.7中__metaclass__不应该定义为全局的,应该放到类的里面去,像下面这样:

class Foo(object):
    #__metaclass__=upper_attr
    # 我们也可以只在这里定义__metaclass__,这样就只会作用于这个类中
    bar = 'bip'

另外在python2.7中改成下面的形式也可以正确运行,使用全局的__metaclass__变量,然后去掉Foo()括号中的object:

__metaclass__ = upper_attr  #  这会作用到这个模块中的所有类
class Foo():
    #__metaclass__=upper_attr
    # 我们也可以只在这里定义__metaclass__,这样就只会作用于这个类中
    bar = 'bip'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值