使用超类方法作为实例方法

Ram*_*sto 3 python inheritance class-method instance-methods

我目前正在阅读 Luciano Ramalho 的优秀著作Fluent Python。在关于接口和继承的一章中,我们构建了一个列表的子类(原始代码请参见github),但我对定义其中一个实例方法的方式感到困惑。对于一个简化的例子,我的困惑是由以下情况引起的:

class ListWithLoadMethod(list):
    load = list.extend
Run Code Online (Sandbox Code Playgroud)

它生成一个新的 list 子类,该子类具有extend方法的别名as load。我们可以通过编写来测试这个类

loaded_list = ListWithLoadMethod(range(4))
print(loaded_list)
loaded_list.extend(range(3))
print(loaded_list)
loaded_list.load(range(3))
print(loaded_list) 
Run Code Online (Sandbox Code Playgroud)

正如预期的那样,它产生:

[0, 1, 2, 3]
[0, 1, 2, 3, 0, 1, 2]
[0, 1, 2, 3, 0, 1, 2, 0, 1, 2]
Run Code Online (Sandbox Code Playgroud)

我的困惑源于类方法和静态方法的区别。当新实例ListWithLoadedMethod被创建,它的子类list,但是当我们初始化我们点了实例loadlist.extend; Python怎么知道list.extend我们不是说load应该指向类的类方法,list而是实际上(显然?)继承超类列表的实例方法?

UMA*_*MAR 7

它实际上不是从超类(列表)继承,而是创建对list.extend方法的引用

当您检查它们的身份时,您会发现它们是内存中的相同对象。

id(list.extend)
Out: 3102044666032

id(ListWithLoadMethod.load)
Out: 3102044666032
Run Code Online (Sandbox Code Playgroud)