JAVA构造函数

在Java中,当为一个类创建了多个构造函数时,有时想在一个构造函数中调用另一个构造函数以减少代码量。这时可以使用this关键字来实现。
通常,当使用this关键字时,它意味着“这个对象”或者“当前对象”,并且它自身产生对当前对象的引用。在一个构造函数中,当给传递给它一个参数列表时,它就有了不同的意义。它将直接的调用能够匹配这个参数列表的构造函数。因此,我么可以直接的调用其它构造函数:


public class Neeke{

 int age = 0;
 String name = "";

 Neeke(int a){
  age = a;
  System.out.println("age:" + age);
 }

 Neeke(String n){
  name = n;
  System.out.println("name:" + name);
 }

 Neeke(int a, String n){
  this(a);
  this.name = n;
  System.out.println("both!");
 }
 
 public static void main(String[] args){
  new Neeke(5, "ssss");
 }
 
}

为什么构造函数Neeke(int a, String n)中的name赋值不可以调用对应的构造方法呢?尽管可以在构造函数中调用构造函数,但是只可以调用一次,并且构造函数的调用必须排在第一位,否则将会出现编译时错误。

 

package gouzao;

public class Gouzao {

 public Gouzao(){
  
  this("this is Gouzao");
  System.out.println("默认构造函数已经被调用");
 }
 
 public Gouzao(String s){
  this(5);
  System.out.println("参数是String的构造函数已经被调用");
 }
 
 public Gouzao(int a){
  this(6.0);
  System.out.println("参数是 int的构造函数已经被调用");
 }
 
 public Gouzao(double a){
 
  System.out.println("参数是double的构造函数已经被调用");
 }
 
 public static void main(String[] args){
  new Gouzao(); 
 }
}

参数是double的构造函数已经被调用
参数是 int的构造函数已经被调用
参数是String的构造函数已经被调用
默认构造函数已经被调用
!!!!!递归性构造函数调用会出现编译错误

 

 

 

 

 

 

### Java 构造函数概述 构造函数用于初始化新创建的对象状态。每个类都有构造函数;如果没有显式定义任何构造函数Java 编译器将提供一个默认的无参构造函数[^3]。 一旦自定义了构造函数,默认的无参构造函数不再存在。因此,在设计类时应考虑是否需要额外定义无参构造函数或其他形式的构造函数。 ### this 关键字调用其他构造函数 在同一类内可以通过 `this` 关键字调用其他的构造函数,从而简化代码并提高可维护性。需要注意的是,使用 `this()` 调用必须放在构造函数的第一条语句位置[^1]。 #### 示例:通过 this() 实现构造函数间调用 ```java public class Person { private String name; private int age; public Person(String name) { // 单参数构造函数 this(name, 0); // 调用了双参数版本 } public Person(String name, int age) { // 双参数构造函数 this.name = name; // 初始化成员变量 this.age = age; } } ``` 上述代码展示了如何利用 `this` 来减少重复代码,单参数构造函数直接委托给更全面的双参数构造函数处理对象初始化工作。 ### 继承中的构造函数行为 对于继承关系下的类来说,子类实例化过程中会先执行其父类的构造过程。如果子类构造器未明确指定要调用哪个超类构造器,则系统自动尝试调用超类的无参构造器。若此时不存在这样的构造器则会导致编译失败[^2]。 为了确保程序能够正常运行,建议总是显示地指明想要使用的父级构造方式: ```java class Animal { protected String type; public Animal() {} // 默认构造器 public Animal(String t){ this.type=t; } } class Dog extends Animal{ public Dog(){ super(); // 明确指出调用Animal的无参构造器 } public Dog(String breed){ super(breed); } } ``` 这里展示了一个简单的继承结构以及如何正确地在子类中调用父类的不同类型的构造器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值