Python是一个具有面向对象特性的高级语言,而面向对象最关键的三个特点就是继承、封装、多态,我们今天就一起来看一下在python中继承是什么意思。
如果不支持继承,语言特性就不值得称为“类”。派生类定义的语法如下所示:
class DerivedClassName(BaseClassName): <statement-1> <statement-N>
名称 BaseClassName 必须定义于包含派生类定义的作用域中,也允许用其他任意表达式代替基类名称所在的位置。例如,当基类定义在另一个模块中的时候,示例如下:
class DerivedClassName(modname.BaseClassName):
派生类定义的执行过程与基类相同,当构造类对象时,基类会被记住。此信息将被用来解析属性引用。如果请求的属性在类中找不到,搜索将转往基类中进行查找。如果基类本身也派生自其他某个类,则此规则将被递归地应用。
派生类的实例化没有任何特殊之处,DerivedClassName()会创建该类的一个新实例。方法引用将按以下方式解析,搜索相应的类属性,如有必要将按基类继承链逐步向下查找,如果产生了一个函数对象则方法引用就生效。
派生类可能会重写其基类的方法。因为方法在调用同一对象的其他方法时没有特殊权限,所以调用同一基类中定义的另一方法的基类方法最终可能会调用覆盖它的派生类的方法。
在派生类中的重载方法实际上可能想要扩展而非简单地替换同名的基类方法。有一种方式可以简单地直接调用基类方法,即调用BaseClassName.methodname(self,arguments)。有时这对客户端来说也是有用的。(请注意仅当此基类可在全局作用域中以BaseClassName的名称被访问时方可使用此方式。)
Python有两个内置函数可被用于继承机制,如下所示:
使用isinstance()来检查一个实例的类型:isinstance(obj,int)仅会在obj.__class__为int或某个派生自int的类时为True。
使用issubclass()来检查类的继承关系:issubclass(bool,int)为True,因为bool是int的子类。但是,issubclass(float,int)为False,因为float不是int的子类。
以上就是关于python中继承是什么的全部内容了。