python中的继承
1. python定义一个类的方法:
class Animal(): def __init__(self,name): self.name=name; def show(self): print self.name; a=Animal(‘dog‘); a.show();
上面定义了一个类Animal,它以class 关键字开头,类中的方法用def关键字开头,类中的init是类的构造方法,在生成实例的时候会自动调用,类中还定义了show方法,它用于打印实例的变量name,每个方法都带有参数self,它可以认为是当前的对象自身。
2. 继承是面向对象的重要特征,它可以提高代码的复用性,从而减少某些代码的重写。继承可以分为单继承和多重继承。python中指定基类的方法是定义派生类时在括号中写入基类的名字,如class derive(base).python可以使用两种单继承的方法,第一种是:
class Animal(): def __init__(self,name): self.name=name; def show(self): print self.name; #a=Animal(‘dog‘); #a.show(); class dog(Animal): def __init__(self,name): Animal.__init__(self,name); def bark(self): print "dog can bark"; d=dog(‘dog‘); d.bark();
上面的dog类继承自基类Animal,它的构造方法中调用了基类的构造方法Animal.__int__(); 这一点需要注意,python的派生类实例化对象时,并不会自动基类的构造方法。派生类对象会首先在本类查找init方法,如果找到就调用然后完成实例化,如果找不到,则会在基类中寻找init方法完成实例化。如果有多个基类,则会按照继承的顺序依次寻找init方法,这个后面还会讲到。
第二种单继承的方法是使用super函数,使用的方法是:
__metaclass__=type; class Animal(): def __init__(self,name): self.name=name; def show(self): print self.name; #a=Animal(‘dog‘); #a.show(); class dog(Animal): def __init__(self,name): super(dog,self).__init__(name); def bark(self): print "dog can bark"; d=dog(‘dog‘); d.bark();
上面的dog类使用super(dog,self),它接受两个参数,派生类名和self。
3. python的多重继承
多重继承只要在括号内填入两个或者更多基类即可,如class derive(base1,base2)class base1(): def __init__(self): print "base1 called"; class base2(): def __init__(self): print "base2 called"; class derive1(base1,base2): def __init__(self): #base1.__init__(self); #base2.__init__(); print "derive1 called"; class derive2(base2,base1): pass;
键入命令:
>>>d1=derive1()
derive1 called
删除derive1中的 __init__(self)方法,则敲入一下命令:
>>>d1=derive1()
base1 called
>>>d2=derive2()
base2 called
>>>d1.show()
this is base1
>>>d2.show()
this is base1
派生类在实例化时,首先查找本类中的构造方法,如果有则调用本类的构造方法,如果没有,则调用第一个调用基类的构造的方法,如上面的derive1如果不定义构造方法,会调用base1的构造方法。除了构造方法外,其它方法的调用方式与此类似,如d1.show(),会调用base1中的show()方法。