可以看下下面的代码,其实是报错的。 a 这个变量不是全局的变量,在 two 这个 方法里,是不能打印的,
class qq():
a = 99
def __init__(self):
pass
def one(self):
a = 5
print(a)
def two(self):
print(a)
w = qq()
w.one()
w.two()
再看下下面的代码,我就是加一个 global 就把 a 变了全局的变量
class qq():
global a
a = 99
def __init__(self):
pass
def one(self):
a = 5
print(a) # 这个 a 输出的就是上面 a 但是他这个是没有改变 全局变量 a 的值
def two(self):
print(a) # 上面说了他是没有改变全局变量的值,所有这个打印的就是,全局变量的值 99
w = qq()
w.one()
w.two()
可以通过 id() 这个方法,去检查 变量的存储的 内存地址,看这个变量是否改变了
接下来就是对 self 这个方法的一个 使用
class a():
def __init__(self):
self.qq = 3
print(id(self.qq))
def b(self):
self.qq = 9
print(self.qq,id(self.qq))
def c(self):
print(self.qq,id(self.qq))
cxp = a()
cxp.b()
cxp.c()
看下面的运行结果
总结:
global 就是申明一个全局变量,不会随着方法的重新赋值而改变,
但是 self 却是会的 ,self 也是申明一个全局变量,但是 后面的方法 如果对他重新赋值了,这个重新赋值的方法也被调用了,那么,这个值就变了。就比如上图的 b 方法 要是这个 方法被调用了,就改变了。要是没被调用,那也不会变