python遗产

时间:2021-04-10 05:37:50

1.    python类方法的定义:

class Animal():
def __init__(self,name):
self.name=name;
def show(self):
print self.name;
a=Animal('dog');
a.show();

上面定义了一个类Animal,它以class keyword开头,类中的方法用defkeyword开头,类中的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()办法。

版权声明:本文博主原创文章,博客,未经同意不得转载。