奇怪的Python行为 - 或者我错过了什么

use*_*821 4 python oop

以下代码:

class House:
    links = []

class Link:
    pass

class Villa(House):
    pass

if __name__ == '__main__':
    house = House()
    villa = Villa()
    link = Link()
    house.links.append(link)

    print house.links
    print villa.links
Run Code Online (Sandbox Code Playgroud)

结果输出:

[<__main__.Link instance at 0xb65a4b0c>] 
[<__main__.Link instance at 0xb65a4b0c>]
Run Code Online (Sandbox Code Playgroud)

我觉得这很奇怪:既然是另一个例子? - 我原以为输出是 - 因为它是另一个实例?:

[<__main__.Link instance at 0xb65a4b0c>] 
[]
Run Code Online (Sandbox Code Playgroud)

将行更改house.links.append(link)house.links = [link]一切按预期工作时.

有人可以解释这种行为吗?

dan*_*ben 19

它是另一个实例,但您已定义links为类变量而不是实例变量.

实例变量将被定义为:

class House(object):  # Always use new-style classes except for backward compatibility
  def __init__(self):
    self.links = []
Run Code Online (Sandbox Code Playgroud)

请注意,在Python中,与其他语言不同,实例变量显式声明为实例的属性.这通常发生在__init__方法中,以确保每个实例都有变量.

然后,子类看起来像这样:

class Villa(House):
  def __init__(self):
    super(Villa, self).__init__()
Run Code Online (Sandbox Code Playgroud)

执行代码会得到正确的结果:

>>> house = House()
>>> villa = Villa()
>>> link = Link()
>>> house.links.append(link)
>>> print house.links
[<__main__.Link instance at 0xcbaa8>]
>>> print villa.links
[]
Run Code Online (Sandbox Code Playgroud)