栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

提供Python 3.6元类的__classcell__示例

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

提供Python 3.6元类的__classcell__示例

如果您使用依赖于类体内的

__class__
可用或引用的super,则会发出警告
__class__

文字实质上是说,如果您定义自定义元类并在将其传递给之前篡改所获得的名称空间,则需要这样做

type.__new__
。你需要小心,始终确保你传递
__classcell__
type.__new__
你的
metaclass.__new__

也就是说,如果您创建了一个要传递的新名称空间,请始终检查是否

__classcell__
在创建的原始名称空间中定义了该名称空间并将其添加:

class Mymeta(type):    def __new__(cls, name, bases, namespace):        my_fancy_new_namespace = {....}          if '__classcell__' in namespace:  my_fancy_new_namespace['__classcell__'] = namespace['__classcell__']        return super().__new__(cls, name, bases, my_fancy_new_namespace)

您在注释中链接的文件实际上是尝试发行的许多补丁程序中的第一个,

issue23722_classcell_reference_validation_v2.diff
也是发出此文件的最后一个补丁程序,发行于23722。

正确执行此操作的示例可以在对Django发出的pull请求中看到,该请求使用此请求修复了Python
3.6中引入的问题:

new_attrs = {'__module__': module}classcell = attrs.pop('__classcell__', None)if classcell is not None:    new_attrs['__classcell__'] = classcellnew_class = super_new(cls, name, bases, new_attrs)

__classcell__
传递之前被简单地添加到新的命名空间
type.__new__



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/641252.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号