• 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 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()办法。


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

  • 相关阅读:
    dubbo开发中使用到的一些服务配置方式
    jedis连接池详解(Redis)
    《Java线程池》:任务拒绝策略
    BlockingQueue(阻塞队列)详解
    洛谷 P3275 BZOJ 2330 [SCOI2011]糖果
    LaTeX的简单使用方法
    洛谷 P1131 BZOJ 1060 [ZJOI2007]时态同步
    洛谷 P2587 BZOJ 1034 [ZJOI2008]泡泡堂
    苦酒入喉心作痛,红酒入鹅鹅想哭——震惊!勒索病毒想哭靠wine感染了Ubuntu16.04
    洛谷 P2144 BZOJ 1003 [FJOI2007]轮状病毒
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4872609.html
Copyright © 2020-2023  润新知