再看继承小程序
真正的大餐来以前,仍是来点儿开胃菜!回顾一下关于类的继承的知识:ide
咱们先看上面的代码,这是一个简单的类继承,咱们能够看到父类Base和子类Son,它们中各有一个Testfunc方法,当咱们实例化子类的对象sonobj时,能够看到初始化方法中黄色框框调用了Testfunc,那么这个时候执行的是哪一个类里面的代码呢?我会告诉你执行的是子类里面的方法,不信就本身试试吧,代码在下面~spa
为何呢?其实这里是绕了一个圈,因此把不少人绕晕了,包括我!后来想一想其实很容易,咱们看最右边的图:3d
若是这样看,咱们是否是就明白了?其实这两段代码表示的是一个意思,尽管Son继承了Base类,父子类中都有一样的方法,可是因为咱们实例化了子类的对象,因此这个在初始化方法里的self.Testfunc,self指的是子类的对象,固然也就先调用子类中的方法啦。因此尽管在第一个例子中,初始化方法在父类执行,可是仍是改变不了它是子类对象的本质,当咱们使用self去调用Testfunc方法时,始终是先调用子类的方法。咱们能够这样理解,尽管儿子继承了父亲的财产,可是花钱的时候,仍是要先花本身的~~~code
1 #_*_coding:utf-8_*_ 2 __author__ = 'Eva_J' 3 class Base(object): 4 def __init__(self,name): 5 self.name = name 6 self.Testfunc() 7 8 def Testfunc(self): 9 print 'do Base Testfunc' 10 11 class Son(Base): 12 def Testfunc(self): 13 print 'do Son Testfunc' 14 15 sonobj = Son('sonobj')
看完刚刚的代码,咱们就知道了对象和self的真实意义,如今再来回忆一下关于继承的顺序问题: 对象
看上面的代码,咱们猜想一下,执行以后,控制台会打印什么呢?先揭晓答案,会打印Base2方法中的内容,缘由很简单:尽管这三个类中都有一样的Testfunc方法,可是,因为计算机在找方法的时候,遵循的顺序是:Base2,Son,Base,因此它会先找到Base2类,而这个类中恰好有它要找的方法,它也就欢欢喜喜的拿去执行啦!blog
1 #_*_coding:utf-8_*_ 2 __author__ = 'Eva_J' 3 class Base(object): 4 def Testfunc(self): 5 print 'do Base Testfunc' 6 7 class Son(Base): 8 def __init__(self,name): 9 self.name = name 10 self.Testfunc() 11 12 def Testfunc(self): 13 print 'do Son Testfunc' 14 15 class Base2(object): 16 def Testfunc(self): 17 print 'do Base2 Testfunc' 18 19 class GrandSon(Base2,Son): 20 pass 21 22 #sonobj = Son('sonobj') 23 sonobj = GrandSon('sonobj')
画个简易类图继承
刚刚咱们只是写了一个小程序,来讲明类之间的继承和对象调用方法之间的联系,可是若是咱们想要hold住一个继承关系复杂的源码逻辑,就须要类图来帮忙!若是你以为我要教你画类图那就大错特错了。。。懒人症重症患者是懒得画那种东西的。。。嘻,先看图!utf-8
对照类图看源码源码
根据上面的图,咱们就拿到了threadingTCPServer的相关类,而且搞清楚了它们之间的继承关系和方法,接下来咱们对照这张简易类图来看看代码执行的过程:
初始化相关过程:
执行serve_forever的相关代码:
就是这样,咱们一路按照调用轨迹去寻找,每次看到一个调用都先对照上面的简易类图,看看有没有重名方法,若是有,就要找到最近的方法并查看里面的内容,以此类推:按照这种方法,就会感受全部代码都在一个文件同样,妈妈不再用担忧我看不懂源码,哈!!!固然啦,这种方法比较山寨,本身内心知道就好,不要告诉别人你实际上是这样看懂源码的~~~