java 父类构造器

  当创建任何java对象时,程序总会首先调用系统的父类非静态初始化块(隐式执行)和父类构造器(从object开始(java程序中所有类的最终父类都是java.lang.Object类,使用语句super(),也可以隐式),其次再调用子类的非静态初始化块和子类构造器,执行初始化,最后返回本类的实例。

例子:

class Creature

{  

  {

    System.out.println("Creature 的非静态初始化块");  

  }

  public Creature()

  {

    System.out.println("Creature 无参数的构造器");  

  }

  public Creature(String name)

  {

    this();

    System.out.println("Creature 带有参数name的构造器,name参数:"+name);  

  }

}

class Animal extends Creature

{  

  {

    System.out.println("Animal 的非静态初始化块");  

  }

  public Animal(String name)

  {

    super(name);

    System.out.println("Animal 带1个参数的构造器,name参数:"+name);  

  }

  public Animal(double weight)

  {

    this(name);

    System.out.println("Animal 带2个参数的构造器,其age:"+age);  

  }

}

class Wolf extends Animal

{  

  {

    System.out.println("Wolf 的非静态初始化块");  

  }

  public Wolf(String name)

  {

    super(“灰太狼”,3);

    System.out.println("Wolf无参数的构造器");  

  }

  public Animal(String name,int age)

  {

    this();

    System.out.println("Wolf的带weight参数的构造器,weight参数:+weight);  

  }

}

public class InitTest

{

  public static void main(String [] args)

  {

    new wolf(5.6);

  }

}

运行程序,输出:

Creature 的非静态初始化块
Creature 无参数的构造器
Creature 带有参数name的构造器,name参数:灰太狼
Animal 的非静态初始化块
Animal 带1个参数的构造器,name参数:灰太狼
Animal 带2个参数的构造器,其age:3
Wolf 的非静态初始化块
Wolf无参数的构造器
Wolf的带weight参数的构造器,weight参数:5.6
笔记:

1.子类构造器执行体的第一行代码使用super显示调用父类构造器,系统将根据super调用里传入的是实参列表来确定调用父类的哪个构造器;

2.子类构造器执行体的第一行代码使用this显示调用本类中重载的构造器,系统将根据this调用里传入的是实参列表来确定调用本类的另一个构造器(执行本类中另一个构造器时即进入第一种情况;

3.子类构造器中没有super()或this()调用时,系统将在调用子类构造器之前,调用父类无参数的构造器;

4.super用于调用父类的构造器;this用于调用本类中另一个重载的构造器;super和this都只能在构造器中使用;都只能作为构造器的第一行代码;

时间: 2024-10-04 05:07:12

java 父类构造器的相关文章

Java 中变量初始化、子类和父类构造器调用的顺序

先说结论 变量初始化 -> 父类构造器 -> 子类构造器 贴代码 Animcal.java 父类 public class Animal { private static int index = 0; private static String getStaticName() { String name = String.format("animal %d" , index++); System.out.println(name); return name; } priva

java中构造器(Constructor)

构造器是一个创建对象时被自动调用的特殊方法,为的是初始化.构造器的名称应与类的名称一致. 当创建一个个对象时,系统会该对象的属性默认初始化,基本类型属性的值为0(数值类型),false(布尔类型),把所有的引用类型设置为null. 构造器可以改变这种默认的初始化. 构造器的作用:是创建Java对象的重要途径,是不是说构造器完全负责创建java对象? 答:是创建java对象的重要途径,通过new关键字调用构造器时,构造器也确实返回了该类的对象,但这个对象并不是完全由构造器负责创建的. 首先要注意的

java中构造器(Constructor)

大部分内容转自:http://tech.it168.com/j/2006-05-18/200605181021879.shtml 构造器是一个创建对象时被自动调用的特殊方法,为的是初始化.构造器的名称应与类的名称一致. 当创建一个个对象时,系统会该对象的属性默认初始化,基本类型属性的值为0(数值类型),false(布尔类型),把所有的引用类型设置为null. 构造器可以改变这种默认的初始化. 构造器的作用:是创建java对象的重要途径,是不是说构造器完全负责创建java对象? 答:是创建java

java(11)构造器

Java中通过new关键字来调用构造器使其在内存中被创建出来. 使用构造器来初始化对象,并且可以通过这个方法为对象分配内存并做些其他的初始化工作和其他操作 类修饰符 类的名称(参数列表) { 方法体 } public.protected.default.private 不能有返回值 package 构造器demo; public class apple { private String s; private apple() { System.out.println("构造器运行了");

java父类调用被子类重写的方法

[转][原文] 1.如果父类构造器调用了被子类重写的方法,且通过子类构造函数创建子类对象,调用了这个父类构造器(无论显示还是隐式),就会导致父类在构造时实际上调用的是子类覆盖的方法(你需要了解java继承中的初始化机制). 例子: [java] view plain copy public abstract class Father { public Father() { display(); } public void display() { System.out.println("Fathe

java类构造器的理解

子类不能继承父类的构造器(构造方法或者构造函数),但是父类的构造器带有参数的,则必须在子类的构造器中显式地通过super关键字调用父类的构造器并配以适当的当属列表. 如果父类有无参构造器,则在子类的构造器中用super调用父类构造器不是必须的,如果没有使用super关键字,系统会自动调用父类的无参构造器. public class InheritanceDemo { public static void main(String args[]) { // SubClass sc = new Sub

Java私有构造器

Java私有构造器:使用private关键字声明的构造函数.由于类的构造函数时私有的,所以此类不能被实例化,同时也不能被继承.<Effective Java>第三条:用私有构造器或者枚举强化Singleton属性.所谓Singleton属性是指仅仅被实例化一次的类.第四条:通过私有构造器强化不可实例化的能力.在Java中实现Singleton有两种方式: public class Elvis { public static final Elvis INSTANCE = new Elvis();

java中 构造器与void

在java中,构造器与void都没有返回值, java编程思想中这么解释构造器的: 构建器属于一种较特殊的方法类型,因为它没有返回值.这与 void 返回值存在着明显的区别.对于void 返回值,尽管方法本身不会自动返回什么,但仍然可以让它返回另一些东西.构建器则不同,它不仅什么也不会自动返回,而且根本不能有任何选择.若存在一个返回值,而且假设我们可以自行选择返回内容,那么编译器多少要知道如何对那个返回值作什么样的处理. 自己运行的例子: public class SimpleConstruct

子类实例化,父类构造器中被调用被子类重写的方法,会执行父类还是子类的呢?

public class Test001 { public static void main(String[] args) { new Child(); } }class Father{ private String name = "f"; public Father(){ tell(); } public void tell(){ System.out.println("father "+this.name); }}class Child extends Fath