本人刚刚接触python
不久, 在学习类继承的时候遇到了一点疑惑, 如下:
class A(object):
x = 1
class B(A):
B.x = 3
print(A.x) # 1
print(B.x) # 1
print(id(A.x)) # 4363216224
print(id(B.x)) # 4363216224
在子类中试图修改这个类属性失败
但是如果我这样改:
class A(object):
x = 1
class B(A):
# B.x = 3
x = 3
print(A.x) # 1
print(B.x) # 3
print(id(A.x)) # 4363216224
print(id(B.x)) # 4363216256
父类和子类中的类属性x
就不一样了, 个人的疑惑如下:
- 在第一种情况中, 似乎无法修改子类的类属性, 请问这是什么原因?
- 第二种情况, 似乎是在
B
中重新创造了一个类属性x
, 不知道是不是这么理解?
总体感觉很混淆, 没有一个清晰的概念来理清这两段代码, 希望能有各位前辈能指点一下, 不胜感激!
更新:
感谢各位前辈的回答, 我用的是3.6, 不过当时是用的jupyter notebook
编辑代码的, 运行是没问题, 但是刚刚自己在别的ide
上面试了一下, 确实会报错, 个人也很迷糊, 不知道是什么情况.
jupyter notebook
截图如下:
所以现在我也很不理解, 有没有别的前辈出现过这样的情况?
1: 这是因为这个是类属性,类属性可以通过类或者实例来访问,当你创建一个类的实例的时候,所有的类属性都会复制一份给这个实例,假设有
class A:
a = A()
b = A()
此时a,b都从类那里得到了类属性x, 用实例也就是a, b都可以访问x, 也可以去修改它,但是它们互不影响
a.x = 2
b.x = 3
此时打印a.x 为2 b.x 为3,A.x 为 1
总之类属性要通过类来修改,创建的实例都有类属性的一份复制。
2:这里是你重写了类的属性,你在子类当中的修改不能影响到父类,要用父类来操作,不然就乱套了。