今天学习了一下python的基础面向对象知识,在继承中发现了一些有趣的问题和方法,做个笔记mark一下
首先看一段简单的继承代码
class my_class: def __init__(self): print "new object" self.name="myclass" def setName(self,name): self.name=name def printName(self): print self.name class my_new_class(my_class): def setAge(self,age): self.age=age; def printAge(self): print self.age a = my_new_class() a.printName() a.setName("Apple") a.printName(); a.setAge(12) a.printAge()
两个简单的继承类,看一下语句的执行结果
>>> new object myclass Apple 12 >>>
可见,子类先执行父类的构造函数,而且能够访问父类的字段name
然后我们再看一个例子
class my_class: def __init__(self): print "new object" self.name="myclass" def setName(self,name): self.name=name def printName(self): print self.name class my_new_class(my_class): def __init__(self): print "my_new _class" ## self.name="hello" def setAge(self,age): self.age=age; def printAge(self): print self.age a = my_new_class() a.printName() a.setName("Apple") a.printName(); a.setAge(12) a.printAge()
在这段代码中,子类新建了一个自己的类构造器,然后我们执行一下结果
my_new _class Traceback (most recent call last): File "D:/python practice/test1", line 21, in <module> a.printName() File "D:/python practice/test1", line 8, in printName print self.name AttributeError: my_new_class instance has no attribute 'name'
结果打印出了子类的构造函数的信息,但是没有父类的构造函数信息,同时报出“没有name属性”这一个错误,然后我们接着把上面代码中的子类构造函数的注释去掉,执行结果如下;
>>> my_new _class hello Apple 12 >>>
可见,子类的构造函数并没有执行父类的构造函数,也自然不会继承在父类构造函数里面的字段属性,但是子类顺理成章的继承了父类的所有方法,如setName();这和Java以及C++等面向对象部分有着显著地区别。
接下来我们来看一下python的子类调用父类的一些方法(这段来自CSDN博主MyKernel)
class A: def method(self, arg): return class B(A): def method(self, arg): # A.method(self,arg) #1 # super(B, self).method(arg) #2 # super().method(arg) #3
[注意] 如果在子类定义外(即在其他函数逻辑内,子类对象去调用父类成员时),则按照:
... ob = B() super(B,ob).method(arg) #调用class B的父类class A的method。 ...