为什么重新绑定 super() 会破坏代码
在 Python 3.x 中,可以在不带参数的情况下调用 super() 函数来访问超类的方法。此行为是通过编译时魔术实现的,该魔术在 super() 和调用类之间建立连接。但是,如果超级名称重新绑定到不同的变量(示例中的 super_),则此连接将被破坏。
原因是 D.R.Y. (不要重复自己)原则。在对超类的调用中显式命名调用类违反了这一原则,并增加了重新绑定问题的风险。此外,使用更改类名的类装饰器也会破坏对原始类对象的引用。
通过在包含 super() 的函数周围的闭包内创建一个不可见的 class 单元, super() 的神奇实现避免了这些问题。单元格引用原始类对象,确保 super() 始终可以访问正确的超类,即使超名称是反弹。
虽然这种行为可能看起来令人惊讶,但重要的是要注意 super() 是经常被滥用。通过简化调用语法并避免无限递归陷阱,更新的实现有助于防止错误。
如果 super 被反弹,则在方法中引用 class 会恢复其功能。这是因为在方法中使用 super 或 class 时会创建单元格。
以上是为什么重新绑定`super()`会破坏你的Python代码?的详细内容。更多信息请关注PHP中文网其他相关文章!