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

java父类引用指向子类对象好处_java子类调用父类属性

方法的重写、重载与动态连接构成多态性 Java之所以引入多态的概念,原因之一就它在类的继承上的问题和C++不同,后者允许多继承,这确实给其带来了非常强大的功能,但是复杂的继承关系也给C++开发者带来了更大的麻烦...子类覆盖父类实现多态: 如果子类继承的超类是一个抽象类,虽然抽象类不能通过new操作符实例化,但是可以创建抽象类的对象引用指向子类对象,以实现运行时多态性,不过,抽象类的子类必须覆盖实现超类中的所有的抽象方法...因为子类是对父类的一个改进和扩充,所以一般子类在功能上较父类更强大,属性较父类更独特: 定义一个父类类型的引用指向一个子类的对象既可以使用子类强大的功能,又可以抽取父类的共性。...所以,父类类型的引用可以调用父类中定义的所有属性和方法,而对于子类中定义而父类中没有的方法,它是无可奈何的; 对于父类中定义的方法,如果子类中重写了该方法,那么父类类型的引用将会调用子类中的这个方法,这就是动态连接...对子类与父类的static问题 ——没覆盖也没继承,子类存有指向父类的引用 对于private ——该方法或属性只能在该类内使用 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

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

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

    《Thinging in Java》的引用 基础类及衍生类,而不再是以前的一个,所以在想象衍生类的结果对象时,可能 会产生一些迷惑。...当然,基础类子对象应该正确地初始化,而且只有一种方法能保证这一点:在构建器中执行初始化,通过调用基础类构建器,后者有足够的能力和权限来执行对基础类的初始化。...在衍生类的构建器中,Java 会自动插入对基础类构建器的调用。...个人总结: super关键字必须写在构造方法的方法体内的非注释代码的首行 子类进行初始化,必须调用父类的构造方法,如果父类的所有构造方法都用private修饰了的话,则无法继承,编译报错....衍生类构造方法调用父类的构造方法,如果父类是无参构造方法,那么编译器会为衍生类的构造方法首行加上super()。 编译器会强迫我们在衍生类构建器的主体中首先设置对基础类构建器的调用。

    1.9K30

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

    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

    Java父类强制转换子类原则

    最近,微信群友在讨论子类父类的转换问题,其实不难,给大家用实例来说明一下就很明了了。 我们知道Java中子类转换成父类是没有任何问题的,那父类可以转换成子类吗?...Fruit fruit1 = new Fruit(); Apple apple1 = new Apple(); apple1 = (Apple) fruit1; // java.lang.ClassCastException...} static class Fruit { } static class Apple extends Fruit { } } 结果是: test1:报类转异常...所以,想让父类强制转换成子类,不是没有可能,除非父类是子类构造出来的实例,不然是不能强转的。 为什么呢?...如上代码,如果父类实例出来的对象是Orange,Orange当然不能强制转成Apple,所以说父类只有该子类对应的实例才能强转。

    2.3K80

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

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

    2.3K20

    子类赋值父类的赋值兼容

    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; // 子类对象给父类变量赋值

    19530

    Java中子类和父类间的调用关系

    3、每个类直接或间接是Object的子类,Object只有一个无参构造方法。...3、每个类直接或间接是Object的子类,Object只有一个无参构造方法。   4、编译器会在每个构造方法的第一行隐式添加父类的默认无参构造器,即添加super()。   ...Must explicitly invoke another constructo   因为父类定义了一个带参数的构造器,因此编译器不会添加默认无参构造方法,但是因为在子类的构造器中没有显式调用父类的某个构造方法...,因此编译器会自动添加super()方法, 但是父类中不存在默认无参构造方法,因此会提示默认无参构造方法未定义错误。   ...Teacher() {   super(10);   }   }   这样,在子类的构造器中显式调用了父类的某个构造器,所以编译器不会自动添加super()方法。

    98830

    Java中类的加载机制---父类和子类的多态调用

    null 1) 上面程序最大的难点,也是最重要的地方就是:在父类的构造函数中调用了虚函数,并且这个函数被子类重载了 2) 继承的时候,子类与父类有着同名的属性和同名的方法,关于同名的属性的初始化过程也是必须要了解的...,对应着前半句的意思;如果他生了小孩,那么这个小孩子是一定有父亲的 到Java代码中这样看,如果我们实例化一个子类,必须先构造这个子类的父类,否则是错误的。...Java 中子类加载的机制是第三个需要理解的地方: 1)相关的类的加载机制还是跟  上面第二点相似,只是在子类初始化的时候必须先去初始化父类 2)只有 等Java机制给子类和所有的父类都分配了内存空间之后...,先搞定堆内存,指向null;才会去  进行属性值的初始化,也就是在栈空间里面是属性的内容,前面分配的内存空间地址这个时候就指向  栈内存的  值; 3)最后就是注意  同名属性不会被子类给覆盖掉的,只是把父类的隐藏掉...,多态的调用 7)子类有重载,所以调用子类的方法,但是子类的baseName还没有初始化,所以就没有直接打出null了 8)父类创建完毕,接下来就是去执行子类的创建工作了, 9)首先为子类的属性进行初始化

    2.8K40

    Python_子类调用父类的方法

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

    4.9K20

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

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

    4.8K10

    子类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)若子类构造函数中显式的调用了父类的某构造函数...,那么就要调用构造方法来初始化该子类对象,但是该类继承自A,所以要先调用父类的构造方法,这里通过super(“B”)显示的调用了父类的带参构造。...执行父类的带参构造前要先对父类中的对象进行初始化,对父类中的c成员进行初始化,调用了C类的无参构造,所以调用顺序为: 先调用C类的无参构造 再调用A类的带参构造 最后调用调用子类的构造 (3...)在JVM调用mian方法之前先用进行静态内容的初始化。...顺序为:父类的静态变量, 父类的静态代码块 ,子类的静态变量,子类的静态代码块。

    2.2K30

    Java子类与父类之间的对象转换(说明继承)

    参考链接: 父类和子类在Java中具有相同的数据成员 在使用Java的多态机制时,常常使用的一个特性便是子类和父类之间的对象转换。...因此,从子类向父类的转换不需要什么限制,只需直接将子类实例赋值给父类变量即可,这也是Java中的多态的实现机制。...在讲述向下转换之前,也许有些刚学java的朋友会有点不解为什么要使用向下转换,使用多态和动态绑定机制通过父类型变量使用子变量不就可以了么(比如我就曾对此感到疑惑)。...这就要考虑到,在继承关系中,有一些方法是不适合由父类定义并由子类继承并重写的,有些方法是子类特有的,不应该通过继承得到,且子类可能也会有自己特有的成员变量,那么在使用多态机制的时候,若我们要通过父类型变量使用到这些子类特有的方法和属性的话...原因是因为,Java编译器并没有聪明到能够在编译阶段就知道父类型变量是哪一个子类的实例,所以,将animal转换为Lion类型的代码:(Lion)animal是能够编译通过的,即使事实上我们能看到animal

    3.8K20

    父类通过泛型获得子类Class类型 以及Type体系

    1、背景介绍 在实现SSH框架中,DAO层向数据库持久化的过程中,因为大部分保存对象的方法都会调用到sava();所有索性就把save delete update select 方法进行封装到父类中,这时候就遇到了个问题...,子类在调用这些方法的时候,需要根据子类的类型获知子类Class类型;这个时候可以通过传入泛型,根据泛型的类型来获取子类的Class类型;  2、实现代码范例 父类:public abstract class...> c = this.getClass(); //子类创建 会创建父类 子类调用时 此处的this是子类 Type t = c.getGenericSuperclass(); //获得带有泛型的父类...,如果父类的方法中需要知道具体子类的Class类型 则可以直接使用Child来使用;   此处的原理就是在子类继承父类的时候 带有泛型 然后子类在创建的时候,会调用父类的构造函数,构造函数中存在this...指的的是子类,然后通过获得父类,再获得父类的泛型 ;通过泛型找到子类类型; 3、原理分析   该实现是通过反射技术实现;下面看具体的分析; 3、1 ParameterizedType 类 ParameterizedType

    5K20

    【JAVA面向对象编程】--- 探索子类如何继承父类

    注意事项: 1.当调用含参的构造方法时系统就不会自动调用无参构造方法 2.对象属性的初始化一定得调用构造方法的 3.子类构造方法:当我们构造Dog时要先调用它的构造方法---> (1).先帮助父类初始化...(通过super(属性)),(2).再通过this.属性 = ...初始化属性。...4.如果子类想要调用父类的静态构造方法,可以在子类中通过方法名()进行访问 静态里面,不能用this 也不能用super 注意:子类构造方法中会默认调用无参构造方法: super(),...【不带参数默认叫咪咪,带参数需要自己传】 父类初始化虽然执行了父类的构造方法,但没有生成父类对象,这里只是帮助子类初始化从父类继承过来的属性。...注意: 1,若父类显式定义无参或者默认的构造方法,在子类构造方法第一行默认有隐含的super(调用,即调用基类构造方法 2.如果父类构造方法是带有参数的,此时需要用户为子类显式定义构造方法,并在子类构造方法中选择合适的父类构造方法调用

    9110
    领券