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
,但是当我们初始化我们点了实例load
来list.extend
; Python怎么知道list.extend
我们不是说load
应该指向类的类方法,list
而是实际上(显然?)继承超类列表的实例方法?
它实际上不是从超类(列表)继承,而是创建对list.extend
方法的引用
当您检查它们的身份时,您会发现它们是内存中的相同对象。
id(list.extend)
Out: 3102044666032
id(ListWithLoadMethod.load)
Out: 3102044666032
Run Code Online (Sandbox Code Playgroud)