类的方法与普通的函数只有一个特别的区别——它们必须有一个额外的第一个参数名称,但是在调用这个方法的时候你不为这个参数赋值,Python会提供这个值。这个特别的变量指对象本身,按照惯例它的名称是self。
self名称不是必须的,在python中self不是关键词,你可以定义成a或b或其它名字都可以,但是约定成俗。使用一个标准的名称有很多优点——你的程序读者可以迅速识别它,如果使用self的话,还有些IDE(集成开发环境)也可以帮助你。
例子说明:创建了一个类MyClass,实例化MyClass得到了MyObject这个对象,然后调用这个对象的方法MyObject.method(arg1,arg2) ,这个过程中,Python会自动转为Myclass.mehod(MyObject,arg1,arg2)
这就是Python的self的原理了。即使你的类的方法不需要任何参数,但还是得给这个方法定义一个self参数,虽然我们在实例化调用的时候不用理会这个参数不用给它赋值。
class Python:
def selfDemo(self):
print 'Python,why self?'
p = Python()
p.selfDemo()
输出:Python,why self?把p.selfDemo()带个参数如:p.selfDemo(p),得到同样的输出结果如果把self去掉的话,
class Python:
def selfDemo():
print 'Python,why self?'
p = Python()
p.selfDemo()
这样就报错了:TypeError: selfDemo() takes no arguments (1 given)self在Python里不是关键字。self代表当前对象的地址。self能避免非限定调用造成的全局变量。