关于java继承的基本概念就不多说了,下面就说说继承使用应该注意的细节问题?

示例 一:

 package com.bizvane;

 class Fu{

     public Fu() {
System.out.println("Fu constructor ....");
}
} class Zi extends Fu{ public Zi() {
System.out.println("Zi constructor ....");
}
} public class ExtendsDemo { public static void main(String[] args) {
new Zi();
}
}

执行结果:

Fu constructor ....
Zi constructor ....

看到这个结果,想必很多人会问,new Zi 类对象,并没有调用Fu 类呀,为什么会出现这个结果?

答案是: 在Zi类无参构造函数第一行会有一个隐式的 super() 语句, 这样就会初始化Fu类。

示例二:

 package com.bizvane;

 class Fu{

     public Fu(int x) {
System.out.println("Fu constructor ...."+x);
}
} class Zi extends Fu{ public Zi(int x) {
System.out.println("Zi constructor ...."+x);
}
} public class ExtendsDemo { public static void main(String[] args) {
new Zi();
} }

执行结果:

在 第 13行编译报错,参数类型不匹配

大家肯定会想为什么呢?

答案是: 首先我们知道每个类中会有一个默认的无参构造函数,现在 Fu 和Zi 类都已经有了有参构造函数,那么默认的无参构造函数就不存在了,结合上面的例子,在Zi 类的有参构造函数第一行会有一个隐式的

super() 语句  当 new Zi(6); 的时候会初始化 Zi 类,super() 调用 Fu 类, 而此时 Fu 类 中已经没有无参构造函数,所以编译就通不过

正确解决办法: 在 Fu 类 加上一个 无参构造函数,或者在 Zi 类的有参构造函数前面加上一个显式 的 super(x)

示例三 :

 class Fu{

     Fu(){
System.out.println("Fu constructor ....A..");
}
Fu(int x){
System.out.println("Fu constructor ....B.."+x);
}
} class Zi{ Zi(){
System.out.println("Zi constructor ....C..");
}
Zi(int x){
System.out.println("Zi constructor ....D.."+x);
}
} class ExtendsDemo{ public static void main(String[] args){
new Zi();
new Zi();
}
}

执行结果:

Fu constructor ....A..
Zi constructor ....C..
Fu constructor ....A..
Zi constructor ....D..6

你心里的答案是否这样的呢? 大家想想为什么吧? 

思考:  this()的用法?

1. 如果子类的构造函数第一行写了this调用了本类其他构造函数,那么super调用父类的语句还有吗?
没有的,因为this() 或者 super(), 只能定义在构造函数的第一行,因为初始化动作要先执行。

2. 父类构造函数中是否有隐式的super()语句呢?
也是有的,记住:只要是构造函数默认第一行都是有super()语句,
那么父类的父类是谁呢? super调用到底是谁的构造函数呢?
java体系在设计,定义了一个所有对象的父类 Object

总结:
类中的构造函数默认第一行都有隐式的super()语句,访问父类中的构造函数,
所以父类的构造函数既可以给自己的对象初始化,也可以给自己的子类对象初始化。

如果默认的隐式super的语句没有对应的构造函数,必须在构造函数中通过this 或者 super 的形式明确调用的构造函数。

java继承使用的细节问题?的更多相关文章

  1. Java - 20 Java 继承

    Java 继承 继承是java面向对象编程技术的一块基石,因为它允许创建分等级层次的类.继承可以理解为一个对象从另一个对象获取属性的过程. 如果类A是类B的父类,而类B是类C的父类,我们也称C是A的子 ...

  2. Java中的泛型 - 细节篇

    前言 大家好啊,我是汤圆,今天给大家带来的是<Java中的泛型 - 细节篇>,希望对大家有帮助,谢谢 细心的观众朋友们可能发现了,现在的标题不再是入门篇,而是各种详细篇,细节篇: 是因为之 ...

  3. 「万字图文」史上最姨母级Java继承详解

    摘要:继承是面向对象软件技术中的一个概念.它使得复用以前的代码非常容易,能够大大缩短开发周期,降低开发费用. 本文分享自华为云社区<「万字图文」史上最姨母级Java继承详解丨[奔跑吧!JAVA] ...

  4. Java泛型中的细节

    Java泛型中的细节 如果没有泛型 学习Java,必不可少的一个过程就是需要掌握泛型.泛型起源于JDK1.5,为什么我们要使用泛型呢?泛型可以使编译器知道一个对象的限定类型是什么,这样编译器就可以在一 ...

  5. Java继承与组合

    Java继承与组合 继承 java 中使用extends关键字表示继承关系,当创建一个类时,如果没有明确指出要继承的类,则是隐式地从根类Object进行继承. 子类继承父类的成员变量 子类能够继承父类 ...

  6. JAVA继承时构造函数的问题

    今天看到java继承部分时,关于构造函数是否继承以及如何使用时遇到了点问题,后来查找相关资料解决了. 下面是我个人的总结: 先创建一个父类,里面有两个构造函数: public class Jisuan ...

  7. Java继承和接口

    接口最关键的作用,也是使用接口最重要的一个原因:能上溯造型至多个基础类.使用接口的第二个原因与使用抽象基础类的原因是一样的:防止客户程序员制作这个类的一个对象,以及规定它仅仅是一个接口.这样便带来了一 ...

  8. Java继承的初始化

    /** * Created by xfyou on 2016/11/2. * Java继承的初始化 */ public class Beetle extends Insect { int k = pr ...

  9. Java—继承、封装、抽象、多态

    类.对象和包 1) 面向对象编程(Object Oriented Programming ,简称 OOP):20世纪70年代以后开始流行. 2) 结构化编程与面向对象编程的区别: A. 在结构化编程中 ...

随机推荐

  1. 九度OJ 1067:n的阶乘 (数字特性)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6476 解决:2471 题目描述: 输入一个整数n,输出n的阶乘 输入: 一个整数n(1<=n<=20) 输出: n的阶乘 样例 ...

  2. Complete space 完备空间与柯西序列 巴拿赫空间与完备空间 完备空间与和希尔伯特空间 封闭closed与完备性complete

    http://www.gatsby.ucl.ac.uk/~gretton/coursefiles/RKHS2013_slides1.pdf RKHS: a function space with a ...

  3. An Overview of Query Optimization in Relational Systems

    An Overview of Query Optimization in Relational Systems

  4. 3D文字特效

    在线演示 本地下载

  5. Contiki 源码风格

    /** * \defgroup coding-style Coding style * * This is how a Doxygen module is documented - start wit ...

  6. scala初步

    1 安装 http://scala-ide.org/ http://scala-lang.org/

  7. listen 69

    Today Is Unlucky for People Who Have Bad Luck Today If you have Paraskevidekatriaphobia, today is no ...

  8. julia

    版本还不成熟,等成熟了再完整的看看吧.

  9. leetcode 23. Merge k Sorted Lists(堆||分治法)

    Merge k sorted linked lists and return it as one sorted list. 题意:把k个已经排好序的链表整合到一个链表中,并且这个链表是排了序的. 题解 ...

  10. 「LOJ#10072」「一本通 3.2 例 1」Sightseeing Trip(无向图最小环问题)(Floyd

    题目描述 原题来自:CEOI 1999 给定一张无向图,求图中一个至少包含 333 个点的环,环上的节点不重复,并且环上的边的长度之和最小.该问题称为无向图的最小环问题.在本题中,你需要输出最小环的方 ...