首先我们来看两组代码运行的结果
代码组一:
class C1:
def func1():
x=10
print("func1的x:",x)
def func2(self):
x=20
print("func2的x:",x)
C1.func1()
C1.func2()
结果如下
代码组二:
class C1:
def func1():
x=10
print("func1的x:",x)
def func2(self):
x=20
print("func2的x:",x)
C1.func1()
c1_obj=C1()
c1_obj.func2()
结果如下
为什么前一个报错后一个不报错?
因为后一个c1_obj=C1()其实是将C1类实例化了 形成了一个对象
就好比是:类是一个不能说话的机器猫(哆啦A梦),它有很多东西但是不能叫出它的名字就不能使用,实例化就相当于可以说话的机器猫,可以使用里面的东西。
所以 参数self就表示当前引用函数的对象(也就是自己,self只是一个形参,不是一定要self这个单词,你变成himself,herself也都可以),所以在后一个引用函数func2()时就首先将自己传给self了,而前一个因为没有实例化就不是对象,所以缺少一个参数
总结:self就是表示当前对象
追加
代码如下
结果如下
可以看出,同样一个实例中的变量是可以被实例中的不同函数调用的