类的方法与普通的函数只有一个特别的区别——它们必须有一个额外的第一个参数名称,但是在调用这个方法的时候你不为这个参数赋值,Python会提供这个值。这个特别的变量指对象本身,按照惯例它的名称是self。
class Any():
def MethodI(self, *args, **kws):
pass
def MethodII(SELF, *args, **kws):
pass
def MethodIII(JustAnArgument, *args, **kws):
pass
any = Any()
any.MethodI()
any.MethodII()
any.MethodIII()
以上也是不会报错的,虽然你可以给这个参数任何名称,但是强烈建议你使用self这个名称——其他名称都是不赞成你使用的。使用一个标准的名称有很多优点——你的程序读者可以迅速识别它,如果使用self的话,还有些IDE(集成开发环境)也可以帮助你。
class Dog():
"""A simple attempt to model a dog."""
def __init__(self, name, age):
"""Initialize name and age attributes."""
self.name = name
self.age = age
def sit(self):
"""Simulate a dog sitting in response to a command."""
print(self.name.title() + " is now sitting.")
def roll_over(self):
"""Simulate rolling over in response to a command."""
print(self.name.title() + " rolled over!")
形参self是必不可少的,必须位于其他形参的前面。为何一定需要self?因为Python在调用这个_init_()方法来创建Dog实例时,将自动传入实参self。
每个与类相关联的方法调用都自动传递实参self(),他是一个指向实例本身的引用,让实例能够访问类中的属性和方法。
你一定很奇怪Python如何给self赋值以及为何你不需要给它赋值。举一个例子会使此变得清晰。假如你有一个类称为MyClass和这个类的一个实例MyObject。当你调用这个对象的方法MyObject.method(arg1, arg2)的时候,这会由Python自动转为MyClass.method(MyObject, arg1, arg2)——这就是self的原理了。
self在Python里不是关键字。self代表当前对象的地址。self能避免非限定调用造成的全局变量。