首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

子类继承父类,父类的初始化

从外部看,似乎新类拥有与基础类相同的接口,而且可包含一些额外的方法和字段。但继承并非仅仅简单地复制基础类的接口了事。创建衍生类的一个对象时,它在其中包含了基础类的一个“子对象”。...这个子对象就象我们根据基础类本身创建了它的一个对象。从外部看,基础类的子对象已封装到衍生类的对象里了。...当然,基础类子对象应该正确地初始化,而且只有一种方法能保证这一点:在构建器中执行初始化,通过调用基础类构建器,后者有足够的能力和权限来执行对基础类的初始化。...个人总结: super关键字必须写在构造方法的方法体内的非注释代码的首行 子类进行初始化,必须调用父类的构造方法,如果父类的所有构造方法都用private修饰了的话,则无法继承,编译报错....衍生类构造方法调用父类的构造方法,如果父类是无参构造方法,那么编译器会为衍生类的构造方法首行加上super()。 编译器会强迫我们在衍生类构建器的主体中首先设置对基础类构建器的调用。

1.9K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    类的实例化顺序

    讲讲类的实例化顺序,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,当 new 的时候,他们的执行顺序。...先说结论,顺序为: 父类静态变量、 父类静态代码块、 子类静态变量、 子类静态代码块、 父类非静态变量(父类实例成员变量)、 父类构造函数、 子类非静态变量(子类实例成员变量)、 子类构造函数。...run.."); B b = new B(); // B b = new B(22); b.methodA(); } } 综合结论,一个类的实例化过程...其次才是父类的构造函数,执行带参数或不带参数的构造函数,依赖于实例化的类的构造函数有没有super父类的带参或不带参的构造函数,上边试验二三已经证明。...最后是类方法的调用执行,如果子类覆盖了父类的method,执行时会先执行子类覆盖的method,method内如果有super.method(),才会调用父类的同名method,否则不会。

    1.2K10

    子类赋值父类的赋值兼容

    C++ 中,类型的匹配检测是非常严格的,但是你会发现一个现象,如果一个类继承了另外一个类,把子类的对象赋值给父类的时候,系统不但不提示错误,而且程序还能顺利的编译通过并运行。...这其实就是 C++ 内部提供的赋值兼容的过程,但是要注意,如果子类数据成员比父类多,则会出现数据截断。...“; cout << “start (“ << _x << “,” << _y << “)” << endl; } protected: int _x; int _y; }; // 继承 Shape 类...“; cout << “radio r = “ << _r << endl; } private: int _r; }; int main(int argc, char* argv[]) { // 实例化一个父类对象...Shape s(3, 5); s.draw(); // 实例化一个子类对象 Circle c(1, 2, 4); c.draw(); cout << “————————“ << endl; // 子类对象给父类变量赋值

    19630

    python中子类调用父类的初始化方法

    ,先放这改天整理下 一、第一种解释: python和其他面向对象语言类似,每个类可以拥有一个或者多个父类,它们从父类那里继承了属性和方法。...如果一个方法在子类的实例中被调用,或者一个属性在子类的实例中被访问,但是该方法或属性在子类中并不存在,那么就会自动的去其父类中进行查找。...子类不显式调用父类的构造方法,而父类构造函数初始化了一些属性,就会出现问题 如果子类和父类都有构造函数,子类其实是重写了父类的构造函数,如果不显式调用父类构造函数,父类的构造函数就不会被执行,导致子类实例访问父类初始化方法中初始的变量就会出现问题...这种方法叫做调用父类的未绑定的构造方法。在调用一个实例的方法时,该方法的self参数会被自动绑定到实例上(称为绑定方法)。但如果直接调用类 的方法(比如A.__init),那么就没有实例会被绑定。...二、第二种解释     在Python中子类继承父类的过程中,如果子类不覆盖父类的__init__()方法,则子类默认将执行与父类一样的初始化方法。

    2.2K10

    Python_子类调用父类的方法

    1.方式一 子类调用父类的方法,包含2中形式的调用。一种形式是在类内部通过继承的方式调用父类的方法,另外一种形式是子类实例化后之后通过继承的方式来调用父类的方法。如下图所示: ?...注意一点,在子类内部通过继承的方式调用父类的属性时,必须要带上self位置参数(self只在实例化过程中和在实例调用属性时才能省略(self本来的含义就是指向实例自己));而实例在通过继承调用父类的属性或方法时...#子类调用父类方法 Person.eat(self) #子类在调用父类方法必须要传self #实例化一个子类 student = Student("周明",23,'男',"11届土木...3班") #调用子类本身的方法 student.course() #通过子类调用父类的方法--->实例化之后来调用父类的方法 student.eat() #调用子类的方法,在子类方法中调用了子类的方法,...#子类调用父类方法 super().eat() #子类在调用父类方法,使用super可以省略self #实例化一个子类 student = Student("周明",23,'男',

    4.9K20

    父类返回子类类型的函数写法

    不过由于我们的这个 Event 的类型比较多,因此希望写一个父类,来一个子类感受下: class DisposableEventBuilder : EventBuilder() { private....build() 我们调用完父类的 retryLimit 方法后,想要设置下 delay,结果发现没有这个方法。 “我 X,这什么玩意儿”,你嘟囔了一句。 因为返回的是父类,所以链式调用掉链子了。...this.retryLimit = retryLimit return this as T } abstract fun build(): PollingEvent } 这个泛型给父类加了一个泛型参数...,这个参数则必须是当前类的子类,那么这样的话我们就可以在返回自身类型的位置返回 T 这个类型了。...子类的改动就很简单了,只需要给父类加一个泛型参数为自己的类型即可: class DisposableEventBuilder : EventBuilder

    4.8K10

    Dart - 抽象类的实例化

    抽象类不能实例化。 继承: 子类比较实现抽象方法,子类可以不重写抽象类中已实现的方法。...接口: 必须实现抽象类中声明的所有方法 二、抽象类的实例化 上面提到了抽象类不能用于创建实例,但是有没有发现,Dart 提供的 Map 和 List 就是抽象类,却可以直接使用它们创建出一个实例对象 final...Map源码 Map 的确是抽象类,不过此时我们也注意到了,在 Map 这个抽象类中,定义了一个工厂构造方法,这就是使抽象类可实例化的关键所在,因为工厂方法可以返回一个实例对象,但这个对象的类型不一定就是当前类... 我们来试着实例化一个抽象类吧 abstract class Animal { void eat(); void sleep() { print("...很遗憾不行,因为在抽象类中定义了工厂构造方法后,在子类中不能定义除工厂构造方法外的其它构造方法了,会报错~ 总结一下: 抽象类无法直接创建实例,但是可以通过实现工厂构造方法来间接实现抽象类的实例化!

    2.8K41

    Java中子类和父类的构造函数?

    参考链接: Java中的继承和构造函数 这篇文章总结了关于Java构造的常见​​问题。  1)为什么创建一个子类对象要也需要调用父类的构造函数? ...如果没有,编译器会插入调用父类构造的语句。这就是为什么在创建子类对象时父类中的构造超函数会被调用。  这里没有创建两个对象,只有一个子对象。...让父类中的构造器被调用的原因是,如果父类有私有的属性需要在它的构造函数中初始化。 ...这是上边的Super类发生的情况。  子类的构造函数,无论有参构造还是无参构造,将会调用父类中的默认的无参构造函数。...3)子类中的显式调用父类构造函数  下面的代码是正常的:    子类(Sub)构造函数显式地调用父类(Super)中的带参构造参数。如果父类中定义了相对应的构造函数,那将会被正常良好的调用。

    2.3K20

    子类调用父类的同名方法和属性

    Python面向对象中,利用子类调用父类的同名方法和属性。...首先我们定义了两个父类,Master和School # @author: 北山啦 # FileName: 12子类调用父类的同名方法 # @time: 2022/6/5 14:54 #父类Master...,子类如何来调用呢 在这里,定义Prentice类,继承了Master和School类,添加了和父类同名属性和方法 调用子类的属性和方法 如果调用了父类的属性和方法,父类属性会自动掩盖子类属性,股灾调用属性前...__init__ print(f'运用{self.kongfu}制作煎饼果子') 调用父类属性和方法 如果调用父类方法,但是为了保障调用到的是父类的属性,必须在方法前调用父类的初始化...__init__ print(f'运用{self.kongfu}制作煎饼果子') '''调用父类方法,但是为了保障调用到的是弗列的属性,必须在方法前调用父类的初始化'''

    1.9K20

    多个jvm实例_java类的实例

    比如说常见的 Person = new Person()代码就是一个将Person类实例化并创建引用的过程。 对于类的实例化,我们关注两个问题: 如何实例化?(类的四种实例化方式) 什么时候实例化?...答案是没有,我们可以认为实例化的时候子类从父类一起拷贝了一份变量,构造函数的执行也是为了能让父类的变量初始化,最后实例化放到内存里的其实是子类+父类的一个混合体!...我们可以知道执行顺序是这样的: 父类代码块 父类的构造方法 子类的代码块 子类的构造方法 4.构造函数的初始化 我们可以从上文知道,实例变量初始化与实例代码块初始化总是发生在构造函数初始化之前,那么我们下面着重看看构造函数初始化过程...这就保证了不管要实例化的类继承了多少父类,我们最终都能让实例继承到所有从父类继承到的属性。 5.小结 结合以上文,我们可以看出类的实例化其实是一个递归的过程。...: 初始化变量 初始化代码块 初始化构造函数 所以最终我们可以总结出类初始化过程中类的各种代码块的执行顺序: 父类静态块 子类静态块 父类代码块 父类构造函数 子类代码块 子类构造函数 验证一下: /

    1.9K10

    Java抽象类及子类实例化顺序和方法调用顺序测试

    测试目的 验证抽象类及子类实例化顺序; 验证抽象类是否可以在子类未实例化时调用子类实现的抽象方法; 验证java的多态性 实例 抽象类: package com.secbro.test.abstractInit...Plant a Banana Eat a Banana 实例化子类 Banana 实例化父类 Plant a Orange Eat a Orange 实例化子类 Orange 结果分析 查看子类、抽象类的构造方法打印结果可知...,实例化子类时先实例化父类。...在抽象类的构造方法中调用了自己未实现的抽象方法,那么对应实例化的子类实现了此方法,在抽象类实例化之后,子类未实例化之前,抽象类可以调用子类实现的抽象方法。...不同的类实例化打印不同的抽象方法实现,java多态的一种表现形式。

    82430

    子类A继承父类B, A a = new A(); 则父类B构造函数、父类B静态代码块、父类B非静态代码块、子类A构造函数、子类A静态代码块、子类A非静态代码块 执行的先后顺序是?

    (1)子类A继承父类B, A a = new A(); 则: 父类B静态代码块->子类A静态代码块->父类B非静态代码块->父类B构造函数->子类A非静态代码块->子类A构造函数 (2)若子类构造函数中显式的调用了父类的某构造函数...System.out.print("B"); } public static void main(String[] args) { new Test(); } } CBB 首先new了一个子类对象...,那么就要调用构造方法来初始化该子类对象,但是该类继承自A,所以要先调用父类的构造方法,这里通过super(“B”)显示的调用了父类的带参构造。...执行父类的带参构造前要先对父类中的对象进行初始化,对父类中的c成员进行初始化,调用了C类的无参构造,所以调用顺序为: 先调用C类的无参构造 再调用A类的带参构造 最后调用调用子类的构造 (3...顺序为:父类的静态变量, 父类的静态代码块 ,子类的静态变量,子类的静态代码块。

    2.2K30

    《C++ 探秘:禁止类的实例化》

    在 C++ 的编程世界里,我们常常会遇到一些特殊的类设计需求。其中,禁止一个类被实例化就是一种很有趣且实用的设计情境。...在这种情况下,禁止实例化可以避免不必要的内存开销和代码逻辑的混乱。 方法一:使用抽象类 抽象类是一种不能被实例化的类,它至少包含一个纯虚函数。...不同的动物子类,如“狗”“猫”等,必须实现自己的“叫声”函数,这样就保证了抽象类“动物”不会被直接实例化,因为它本身的“叫声”函数没有具体的实现,只是一个抽象的概念。...当我们看到一个类是抽象类时,马上就知道它不应该被实例化,而且它强制要求子类实现特定的纯虚函数,保证了多态性的正确实现。...比如在一个游戏开发框架中,“游戏元素”类可能是抽象的,它定义了游戏中各种元素的通用属性和行为接口,通过禁止实例化,我们可以确保开发人员必须创建具体的游戏元素子类,如“角色”“道具”等,从而保证了游戏元素的规范性和可扩展性

    8800
    领券