1.子类无构造函数,超类无构造函数,创建的无参数的对象:

编译通过。

  class A
{ } class B extends A
{ }
public class Testeeer
{
public static void main(String [] args)
{
B b_01=new B();
}
}

2.子类有无参数构造函数,超类无构造函数,创建的无参数的对象:

运行结果:

调用了B的无参构造函数

  class A
{ }
class B extends A
{
public B()
{
System.out.println("调用了B的无参构造函数");
}
} public class Testeeer
{
public static void main(String [] args)
{
B b_01=new B(); }
}

3.子类无构造函数,超类有无参数构造函数,创建的无参数的对象:

运行结果:

调用了A的无参构造函数

  class A
{
public A()
{
System.out.println("调用了A的无参构造函数");
}
}
class B extends A
{ } public class Testeeer
{
public static void main(String [] args)
{
B b_01=new B(); }
}

4.子类有无参数构造函数,超类有无参数构造函数,创建的无参数的对象:

运行结果:

调用了A的无参构造函数

调用了B的无参构造函数

  class A
{
public A()
{
System.out.println("调用了A的无参构造函数");
}
}
class B extends A
{
public B()
{
System.out.println("调用了B的无参构造函数");
}
} public class Testeeer
{
public static void main(String [] args)
{
B b_01=new B(); }
}

5.子类无构造函数,超类无构造函数,创建的有参数的对象:

编译不成功:

  class A
{ } class B extends A
{ } public class Testeeer
{
public static void main(String [] args)
{ B b_02=new B("你好");
}
}

6.子类有无参数构造函数,超类无构造函数,创建的有参数的对象:

编译不成功:

  class A
{ } class B extends A
{
public B()
{
System.out.println("调用了B的无参构造函数");
}
} public class Testeeer
{
public static void main(String [] args)
{ B b_02=new B("你好");
}
}

7.子类无构造函数,超类有无参数构造函数,创建的有参数的对象:

编译不成功:

  class A
{
public A()
{
System.out.println("调用了A的无参构造函数");
}
} class B extends A
{ } public class Testeeer
{
public static void main(String [] args)
{ B b_02=new B("你好");
}
}

8.子类有无参数构造函数,超类有无参数构造函数,创建的有参数的对象:

编译不成功:

  class A
{
public A()
{
System.out.println("调用了A的无参构造函数");
}
} class B extends A
{
public B()
{
System.out.println("调用了B的无参构造函数");
}
} public class Testeeer
{
public static void main(String [] args)
{ B b_02=new B("你好");
}
}

9.子类有有参数构造函数,超类无构造函数,创建的有参数的对象:

编译成功;

运行结果:

 class A
{ }
class B extends A
{ public B(String mess)
{
System.out.println("调用了B的有参构造函数\n"+
"参数内容为:"+mess);
} } public class Testeeer
{
public static void main(String [] args)
{
B b_02=new B("你好");
}
}

10.子类有有参数构造函数,超类有有参数构造函数,创建的有参数的对象:

编译失败:

 class A
{
public A(String mess)
{
System.out.println("调用了A的有参构造函数\n"+
"参数内容为:"+mess);
}
}
class B extends A
{ public B(String mess)
{
System.out.println("调用了B的有参构造函数\n"+
"参数内容为:"+mess);
} } public class Testeeer
{
public static void main(String [] args)
{
B b_02=new B("你好");
}
}

11.子类有有参数构造函数(首行定义super),超类有有参数构造函数,创建的有参数的对象:

编译成功;

运行结果:

 class A
{
public A(String mess)
{
System.out.println("调用了A的有参构造函数\n"+
"参数内容为:"+mess);
}
}
class B extends A
{ public B(String mess)
{
super(mess);
System.out.println("调用了B的有参构造函数\n"+
"参数内容为:"+mess);
} } public class Testeeer
{
public static void main(String [] args)
{
B b_02=new B("你好");
}
}

12.子类有有参数构造函数,超类有有参数构造函数和无参数的构造函数,创建的有参数的对象:

编译成功;

运行结果:

 class A
{
public A(String mess)
{
System.out.println("调用了A的有参构造函数\n"+
"参数内容为:"+mess);
}
public A()
{
System.out.println("调用了A的无参构造函数");
}
}
class B extends A
{ public B(String mess)
{ System.out.println("调用了B的有参构造函数\n"+
"参数内容为:"+mess);
} } public class Testeeer
{
public static void main(String [] args)
{
B b_02=new B("你好");
}
}

13.子类有有参数构造函数,超类默认无构造函数,创建的有参数的对象:

编译成功;

运行结果:

 class A
{ }
class B extends A
{ public B(String mess)
{ System.out.println("调用了B的有参构造函数\n"+
"参数内容为:"+mess);
} } public class Testeeer
{
public static void main(String [] args)
{
B b_02=new B("你好");
}
}

1.一旦你在超类或者子类中定义了有参数的构造函数,那么子类和超类中系统默认提供的无参构造函数将不复存在。

2.在子类的构造函数构造前,一定要完成超类的构造函数构造的过程。(那么依据这样的惯性行为,主程序入口处创建的对象的两种类型(有参数或者无参数)将会直接决定子类所调用的构造函数类型(与对象的类型相同)(有参数或者无参数),但是在完成子类构造函数前,先要去完成超类的构造函数。)

2.1如果是无参数的对象创建:

2.1.1超类:默认                                子类:无参构造函数                                    运行:超类默认,子类无参构造

2.1.2超类:无参构造函数                     子类:默认                                               运行:超类无参构造函数,子类默认

2.1.3超类:默认                                子类:默认                                               运行:超类默认,子类默认

2.1.4超类:无参构造函数                     子类:无参构造函数                                    运行:超类无参构造函数,子类无参构造函数

2.2如果是有参数的对象创建:

2.2.1超类:有参构造数                         子类:有参构造函数{定义中首行super(形参)}        运行:超类有参构造数,子类有参构造函数

2.2.2超类:默认                                 子类:有参构造函数                                             运行:超类默认,子类有参构造函数

2.2.3超类:无参构造数                         子类:有参构造函数                                             运行:超类无参构造数,子类有参构造函数

2.2.4超类:有参构造和无参构造              子类:有参构造函数                                             运行:无参构造,子类有参构造函数

2.2.5超类:有参构造和无参构造              子类:有参构造函数{定义中首行super(形参)}         运行:超类有参构造,子类有参构造函数

JAVA构造函数在超类与子类定义鲁波总结的更多相关文章

  1. JAVA构造函数在超类和子类调用注意事项

    1.构造函数:        当子类继承一个父类时,构造子类时需要调用父类的构造函数,存在三种情况        (1),父类无构造函数或者一个无参数构造函数,子类若无构造函数或者有无参数构造函数,子 ...

  2. java构造函数是否可继承,以及子类构造函数可否不使用super调用超类构造函数

    问题一:java的构造函数能否被继承? 笔者初学java看的一本书说:“java的子类自然的继承其超类的“非private成员”. 通常java的构造函数被设置为public的(若你不写构造函数,ja ...

  3. Java核心技术第五章——1.类、超类、子类(2)

    继上一篇Java核心技术第五章——1.类.超类.子类(1) 6.重载解析 假如调用ClassName.Method(args) 1.编译器列出类ClassName所有名为Method的方法. 2.编译 ...

  4. Java核心技术第五章——1.类、超类、子类(1)

    1.定义子类: 关键字extends表明正在构造的新类派生与一个已存在的类.已存在的类称为超类.基类或父类:新类称为子类.派生类或孩子类.超类和子类是Java程序员最常用的两个术语(emmm~~我觉得 ...

  5. Java:【面向对象:类的定义,静态变量,成员变量,构造函数,封装与私有,this】

    本文内容: 什么是面对对象 类的定义与对象实例化 成员变量 成员变量的有效范围 成员变量的赋值 静态变量.方法与实例变量.方法 构造函数 封装与私有 this关键字 注:函数和方法是一样东西.[由于我 ...

  6. Core Java (十一) Java 继承,类,超类和子类

    Core Java (十一) Java 继承,类,超类和子类 标签: javaJavaJAVA 2013-01-22 17:08 1274人阅读 评论(0) 收藏 举报  分类: java(58) 读 ...

  7. Java 构造函数(抽象类中的构造函数) 和 加载

    博客分类: 面向对象设计的原则 与 概念   1. Java 的构造函数 与初始化块: a. 抽象类的构造函数 若果在父类中(也就是抽象类)中显示的写了有参数的构造函数,在子类是就必须写一个构造函数来 ...

  8. JavaScript 超类与子类 继承

    //超类和子类 继承的实现 function R(w, h) { var date = new Date(); this.width = w; this.height = h; this.create ...

  9. JS 超类和子类

    此篇由别的大神的博客与<javascript高级程序设计>一书整理而来 原博客地址:https://hyj1254.iteye.com/blog/628555 看到javascript高级 ...

随机推荐

  1. v-if和v-show小对比

    相同点 都可以控制元素的显示与不显示.在判断DOM节点是否要显示. 不同点 1.实现方式 v-if是根据后面的数据的真假判断直接从DOM树上删除或重建元素节点. v-show 只是修改元素的css的样 ...

  2. Linux文件权限总结

    一.用户组和用户 Linux是一个多用户.多任务环境,如下图,GroupA代表一个用户组,GroupB代表一个用户组,root是超级用户. Linux中,任何一个文件都有User.Group和othe ...

  3. 关于Gradle2.0的翻译说明

    Gradle1.12的翻译情况 Gradle实际上在4月16日就已经在对应的OmegaT项目上完成了翻译,后因项目繁忙,直到7月20日才完成了Github上Gradledoc项目及七牛站点的更新. 总 ...

  4. Kafka消费者生产者实例

    为了更为直观展示Kafka的消息生产消费的过程,我会从基于Console和基于Application两个方面介绍使用实例.Kafka是一个分布式流处理平台,具体来说有三层含义: 它允许发布和订阅记录流 ...

  5. UCB算法

    前言: 来万物花开这家创业公司实习,也真是一波三折.先实习了三天,每天下午到公司工作到晚上.工作时间是每天下午到晚上9.30.结果每天上午没法用心干实验室的活了,下午在公司工作的时候,总是提心吊胆,手 ...

  6. vuex秘籍

    vue项目开发中,大型项目一般vuex所需要存储的状态一般都很都,这时,我们便需要进性模块化划分,然后 再页面中采用映射来实现state的调用: 目录一般如下: store为总的状态库存放文件. mo ...

  7. BZOJ3529 [Sdoi2014]数表【莫比乌斯反演】

    Description 有一张 n×m 的数表,其第 i 行第 j 列(1 <= i <= n, 1 <= j <= m)的数值为 能同时整除 i 和 j 的所有自然数之和.给 ...

  8. 快速学习MD5的方法

    MD5加密的Java实现 在各种应用系统中,如果需要设置账户,那么就会涉及到存储用户账户信息的问题,为了保证所存储账户信息的安全,通常会采用MD5加密的方式来,进行存储.首先,简单得介绍一下,什么是M ...

  9. [CF895E]Eyes Closed

    luogu description 一个序列\(a_i\),支持一下两种操作. \(1\ \ l_1\ \ r_1\ \ l_2\ \ r_2\): 随机交换区间\([l_1,r_1]\)和\([l_ ...

  10. ffmpeg && nginx hls

    备注: 使用ffmpeg 将视频转换为hls,并使用nginx 提供服务,实现点播功能,没有使用rtmp 插件 1.  ffmpeg 命令生成文件 a. ts ffmpeg -y -i mydemo. ...