面向对象----类变量小坑

先看一段代码

class A:
	name = "a"
	def __init__(self):
		pass

a = A()
print(a.name)
print("-"*10)

b = A()
b.name = "b"
print(b.name)
print(a.name)
print("-"*10)

c = A()
c.name = "c"
print(c.name)
print(b.name)
print(a.name)

在这里插入图片描述看起来没什么问题,再来看一段代码

class A:
	name = ["a"]
	def __init__(self):
		pass

a = A()
print(a.name)
print("-"*10)

b = A()
b.name.append("b")
print(b.name)
print(a.name)
print("-"*10)

c = A()
c.name.append("c")
print(c.name)
print(b.name)
print(a.name)

在这里插入图片描述
我们发现,当一个实例更改自身的类变量时其他的实例也在跟着变化,这是问什么呢? 与python数据类型有关

python的变量分为可变类型和不可变类型。
可变类型:list,dict
不可变类型:string,number,tuple
对可变类型的变量做操作时,会返回一个新的变量,原有的变量值没有发生变化,而是又开辟一块内存来放置新的值,而不可变类型则不同,它会对原来的值进行处理。

不可变类型:

a = "a"
print(id(a))

b = a.upper()
print(b)
print(id(b))

print(a)
print(id(a))

在这里插入图片描述我们发现对a进行操作时,返回了一个新的对象,a本身并没有变化

可变类型

c = [1,2,3]
print(id(c))

d = c.append(4)
print(d)
print(id(d))

print(c)
print(id(c))

在这里插入图片描述
c对象发生了变化,并没有创建新变量。

总结:

类变量是不可变类型,每次实例化对象时重新开辟内存创建自有的类变量

类变量是可变类型,一个实例更改,其他实例跟着变

发布了62 篇原创文章 · 获赞 13 · 访问量 2965

猜你喜欢

转载自blog.csdn.net/Yanghongru/article/details/105321945
今日推荐