Python:类
定义类:
class A:
def __init__(self, name):
self.name = name
def say(self):
print self.name
def __del__(self):
print "delete: %s" % self.name
- python类的所有方法定义都必须至少含有一个参数,也就是
self
参数。在方法定义时作为第一个参数存在,self参数是类实例的引用。 __init__
方法相当于构造函数,在获取类实例的时候会执行。__del__
方法相当于析构函数,会由系统自动调用(类似垃圾回收),也可以通过del对象
主动调用。- 上例在
__init__
方法里定义了一个对象的变量name
,可以在类内其他地方通过self.name
引用。
获取类的实例并调用类方法:
a = A('Jim') #不用new
a.say() #Jim
A.say(a) #Jim
调用类的方法有两种方式:
对象.方法名
,此种方式self参数不需要指定,对象引用作为实参自动传入。类名.方法名
,此种方式self参数需要指定为类实例的引用。
类变量和对象变量:
class A:
pass
a = A()
print A.j #报错,因为A类中不存在类变量j
A.i = 1 #在A类中添加类变量i,并赋值1
print A.i #打印1
print a.i #打印1,这里的a.i实际上取到的是类A的类变量i,非对象a的对象变量i(其尚不存在)
a.j = 2 #在对象a中添加对象变量j,并赋值2
print A.j #报错,因为A类中不存在类变量j
print a.j #打印2
a.i = 3 #在对象a中添加对象变量i,并赋值3
b = A()
print A.i #打印1,A.i取到的是A类中的类变量i
print a.i #打印3,a.i取到的是a对象中的对象变量i,取不到类A中的类变量i(因为重名优先获取对象变量)
print b.i #打印1,b.i取到的是A类中的类变量i
总结:
- 对象的变量称为对象的域;类的变量称为类的域(相当于类静态变量)。类的域和方法合称类的属性。(我们没用域,而用了变量这个称呼)。
- 类和对象的变量可以在类定义后随意添加。
- 如果我们用
对象.i
取用变量(取用而非赋值),会先试图取用对象变量i
,若不存在则试图取用对象所属类中的类变量i
,若还不存在则报错。 - 可使用对象引用获取类变量值(在不存在重名的对象变量时),但不能用对象引用给类变量赋值(会创建同名对象变量)。
定义类变量:
在类内直接定义的变量是类变量,不属于某个特定对象,相当于静态变量,如:
class P:
__pri = "private via"
count = 1
print P.count #打印1
print P.__pri #报错,类P中没有名称为__pri的属性
- 使用类变量通常用:
类名.变量名
- 类的属性默认是公有的;类定义中,变量名为双下划线开头的变量是私有的(依靠约定来保证)。
类的继承:
在类定义时,类名称后紧跟一个元组名,此类即为以元组的元素为父类的子类:
class SubClass(SuperClass):
pass
class SubClass(SuperClass1, SuperClass2):
pass
- 若类没有显式的定义
__init__
方法,则python会自动生成一个__init__(self)
方法;且如果这个类有父类,此子类自动生成的__init__(self)
方法会依次调用父类的__init__(self)
方法,若父类中没有__init__(self)
这样的方法,执行就会报错。 - 若显式定义
__init__
方法,父类的__init__
方法不会自动调用,需要代码显式调用。这和java不同,java会自动在构造方法的第一句加入super()
语句。