跟老齐学跟老齐学Python之编写类之四再论继承之编写类之四再论继承
在上一讲代码的基础上,做进一步修改,成为了如下程序,请看官研习这个程序:
复制代码 代码如下:
#!/usr/bin/env python
#coding:utf-8
class Person:
def __init__(self, name, email):
self.name = name
self.email = email
class Programmer(Person):
def __init__(self, name,email,lang, system, website):
Person.__init__(self,name,email)
self.lang = lang
self.system = system
self.website = website
class Pythoner(Programmer):
def __init__(self,name,email):
Programmer.__init__(self,name,email,”python”,”Ubuntu”,”qiwsir.github.io”)
if __name__==”__main__”:
writer = Pythoner(“qiwsir”,”qiwsir@gmail.com”)
print “name=”,writer.name
print “lang=”,writer.lang
print “email=”,writer.email
print “system=”,writer.system
print “website=”,writer.website
#运行结果
name= qiwsir
lang= python
email= qiwsir@gmail.com
system= Ubuntu
website= qiwsir.github.io
对结果很满意,再看程序中的继承关系:Pythoner <– Programmer <– Person,从上面的过程中不难看出,继承能够减少代
码重复,是的代码更简练。另外,在继承的时候,也可以在函数中对参数进行默认赋值。
为了能够突出继承问题的探究,还是用那种简单的类来做实验。
多余的B
复制代码 代码如下:
#!/usr/bin/env python
#coding:utf-8
class A:
def __init__(self):
print “aaa”
class B(A):
pass
if __name__==”__main__”:
a = A()
b = B()
#运行结果
aaa
aaa
B继承A,没有任何修改地继承,B就可以不用写任何东西了,或者说B本质上就是一个多余。在真实的编程过程中,没有这样
写的,这里仅仅是为了向看官展示一下继承的含义罢了。
复制代码 代码如下:
##首个继承有效