python子类调用父类的方法

python子类调用父类的方法

python和其他面向对象语言类似,每个类可以拥有一个或者多个父类,它们从父类那里继承了属性和方法。如果一个方法在子类的实例中被调用,或者一个属性在子类的实例中被访问,但是该方法或属性在子类中并不存在,那么就会自动的去其父类中进行查找。

继承父类后,就能调用父类方法和访问父类属性,而要完成整个集成过程,子类是需要调用的构造函数的。

子类不显式调用父类的构造方法,而父类构造函数初始化了一些属性,就会出现问题

如果子类和父类都有构造函数,子类其实是重写了父类的构造函数,如果不显式调用父类构造函数,父类的构造函数就不会被执行,导致子类实例访问父类初始化方法中初始的变量就会出现问题。

class A:
def __init__(self):
self.namea="aaa"

def funca(self):
print "function a : %s"%self.namea

class B(A):
def __init__(self):
self.nameb="bbb"

def funcb(self):
print "function b : %s"%self.nameb

b=B()
print b.nameb
b.funcb()

b.funca()

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

class A:

def __init__(self):

self.namea="aaa"

def funca(self):

print "function a : %s"%self.namea

class B(A):

def __init__(self):

self.nameb="bbb"

def funcb(self):

print "function b : %s"%self.nameb

b=B()

print b.nameb

b.funcb()

b.funca()

结果:

bbb
function b : bbb
Traceback (most recent call last):
File "D:\workbench\python\MyPythonProject\test\study\overwrite_method.py", line 19, in <module>
print b.funca()
File "D:\workbench\python\MyPythonProject\test\study\overwrite_method.py", line 6, in funca
print "function a : %s"%self.namea
AttributeError: B instance has no attribute ‘namea‘

1

2

3

4

5

6

7

8

bbb

function b : bbb

Traceback (most recent call last):

File "D:\workbench\python\MyPythonProject\test\study\overwrite_method.py", line 19, in <module>

print b.funca()

File "D:\workbench\python\MyPythonProject\test\study\overwrite_method.py", line 6, in funca

print "function a : %s"%self.namea

AttributeError: B instance has no attribute ‘namea‘

在子类中,构造函数被重写,但新的构造方法没有任何关于初始化父类的namea属性的代码,为了达到预期的效果,子类的构造方法必须调用其父类的构造方法来进行基本的初始化。有两种方法能达到这个目的:调用超类构造方法的未绑定版本,或者使用super函数。

方法一:调用未绑定的超类构造方法

修改代码,多增一行:

class A:
def __init__(self):
self.namea="aaa"

def funca(self):
print "function a : %s"%self.namea

class B(A):
def __init__(self):
#这一行解决了问题
A.__init__(self)
self.nameb="bbb"

def funcb(self):
print "function b : %s"%self.nameb

b=B()
print b.nameb
b.funcb()

b.funca()

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

class A:

def __init__(self):

self.namea="aaa"

def funca(self):

print "function a : %s"%self.namea

class B(A):

def __init__(self):

#这一行解决了问题

A.__init__(self)

self.nameb="bbb"

def funcb(self):

print "function b : %s"%self.nameb

b=B()

print b.nameb

b.funcb()

b.funca()

如上有注释的一行解决了该问题,直接使用父类名称调用其构造函数即可。

这种方法叫做调用父类的未绑定的构造方法。在调用一个实例的方法时,该方法的self参数会被自动绑定到实例上(称为绑定方法)。但如果直接调用类 的方法(比如A.__init),那么就没有实例会被绑定。这样就可以自由的提供需要的self参数,这种方法称为未绑定unbound方法。

通过将当前的实例作为self参数提供给未绑定方法,B类就能使用其父类构造方法的所有实现,从而namea变量被设置。

方法二:使用super函数

修改代码,这次需要增加在原来代码上增加2行:

#父类需要继承object对象
class A(object):
def __init__(self):
self.namea="aaa"

def funca(self):
print "function a : %s"%self.namea

class B(A):
def __init__(self):
#这一行解决问题
super(B,self).__init__()
self.nameb="bbb"

def funcb(self):
print "function b : %s"%self.nameb

b=B()
print b.nameb
b.funcb()

b.funca()

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

#父类需要继承object对象

class A(object):

def __init__(self):

self.namea="aaa"

def funca(self):

print "function a : %s"%self.namea

class B(A):

def __init__(self):

#这一行解决问题

super(B,self).__init__()

self.nameb="bbb"

def funcb(self):

print "function b : %s"%self.nameb

b=B()

print b.nameb

b.funcb()

b.funca()

如上有注释的为新增的代码,其中第一句让类A继承自object类,这样才能使用super函数,因为这是python的“新式类”支持的特性。当前的雷和对象可以作为super函数的参数使用,调用函数返回的对象的任何方法都是调用超类的方法,而不是当前类的方法。

super函数会返回一个super对象,这个对象负责进行方法解析,解析过程其会自动查找所有的父类以及父类的父类。

方法一更直观,方法二可以一次初始化所有超类

super函数比在超累中直接调用未绑定方法更直观,但是其最大的有点是如果子类继承了多个父类,它只需要使用一次super函数就可以。然而如果没有这个需求,直接使用A.__init__(self)更直观一些。

时间: 2024-12-17 02:20:19

python子类调用父类的方法的相关文章

python基础之继承实现原理、子类调用父类的方法、封装

继承实现原理 python中的类可以同时继承多个父类,继承的顺序有两种:深度优先和广度优先. 一般来讲,经典类在多继承的情况下会按照深度优先的方式查找,新式类会按照广度优先的方式查找 示例解析: 没有共同头部父类的类型 1 class E: 2 def test(self): 3 print('from E') 4 # pass 5 class F: 6 def test(self): 7 print('from F') 8 # pass 9 10 class C: 11 def test(se

Python_子类调用父类的方法

1.方式一子类调用父类的方法,包含2中形式的调用.一种形式是在类内部通过继承的方式调用父类的方法,另外一种形式是子类实例化后之后通过继承的方式来调用父类的方法.如下图所示:注意一点,在子类内部通过继承的方式调用父类的属性时,必须要带上self位置参数(self只在实例化过程中和在实例调用属性时才能省略(self本来的含义就是指向实例自己)):而实例在通过继承调用父类的属性或方法时,则不用传self参数,因为实例已经实例化了呀!!!该部分的代码块如下:注意一点,在子类内部通过继承的方式调用父类的属

8.python之面相对象part.5(子类调用父类的方法,以及super关键字)

python中子类要调用父类的某个方法,在python早期版本中是这样实现的: class A: def __init__(self): print "enter A" print "leave A" class B(A): def __init__(self): print "enter B" A.__init__(self) print "leave B" b = B() >>>enter B enter

第52天学习python 子类调用父类方法

#子类中调用父类#初步程序# class Vehicle:#定义交通工具# Country="China"# def __init__(self,name,speed,load):# self.name=name# self.spedd=speed# self.load=load## def run(self):# print("开动了")## class Subway(Vehicle):#定义个地铁# def __init__(self,name,speed,lo

#python#子类调用父类函数的方法

Python中的子类中的__init__()函数会覆盖父类的函数,一些情况往往需要在子类里调用父类函数. 如下例程里,???处是需要调用父类函数的地方,接下来结合例程具体介绍. 1 1 # -*- coding:utf-8 -*- 2 2 class Student: 3 3 def __init__(self,name): 4 4 self.name=name 5 5 def ps(self): 6 6 print('I am %s'%self.name) 7 7 8 8 class Scor

java继承-子类调用父类的方法中包含子类重写的方法

# 看题目是不是很绕,这个我也不知道怎么才能更简单的表达了... # 先看代码: public class Common { public static void main(String[] args) { Sub sub = new Sub(); sub.testSub(); } } class Parent { protected boolean test() { throw new RuntimeException(); } protected void testParent() { if

Python__子类调用父类的方法

# class OldboyPeople:# school = 'oldboy'# def __init__(self,name,age,sex):# self.name=name# self.age=age# self.sex=sex## def eat(self):# print('is eating')# def teach(self):# print('这是父类的teach')## class OldboyTeacher(OldboyPeople):# def __init__(self

抽象类,子类调用弗雷的方法,super

1\ 抽象类 子类 必须与子类一样的函数名, 限制了子类名必须与父类名一样,就定义了一个标准,做统一, 抽象类,不能被实例化,作用就是定义标准,不用具体实例化 1 Python本身不提供抽象类和接口机制,要想实现抽象类, 2 可以借助abc模块.ABC是Abstract(摘要) Base(基础,底部) Class的缩写. 3 4 5 abc.ABCMeta 这是用来生成抽象基础类的元类.由它生成的类可以被直接继承. 6 7 import abc 8 class File(mataclass=ab

继承实现的原理、子类中调用父类的方法、封装

一.继承实现的原来 1.继承顺序 Python的类可以继承多个类.继承多个类的时候,其属性的寻找的方法有两种,分别是深度优先和广度优先. 如下的结构,新式类和经典类的属性查找顺序都一致.顺序为D--->A--->E--->B--->C. class E: def test(self): print('from E') class A(E): def test(self): print('from A') class B: def test(self): print('from B'