Java无参构造方法的作用
class Person{
private String name ; // 表示人的姓名
private int age ; // 表示人的年龄
public void tell(){ // 定义说话的方法
System.out.println(“姓名:” + this.getName() + “,年龄:” + this.getAge()) ;
}
public Person(){
System.out.println("########");
}
public void setName(String n){
name = n ;
}
public void setAge(int a){
if(a>=0&&a<=200){
age = a ;
}
}
public String getName(){
return name ;
}
public int getAge(){
return age ;
}
};
public class OODemo10{
public static void main(String args[]){
Person per = new Person() ; // 实例化对象
System.out.println(per.getName());
System.out.println(per.getAge());
}
};随便拷贝了一个代码
问题:我知道结果会输出
########
null
0
我们说构造方法(这里指的是有参的构造方法)的主要目的是为了类中的属性初始化,那么无参构造方法的目的
是不是也是这样呢?
并不是这样的,而是因为子类继承父类的时候会自动继承默认的构造函数(这里指无参的构造函数)。而子类里面
已经有一个带有参数的构造函数了,如果没有写那个默认的不带参数的构造函数的话,继承的时候就会报错,因为系
统不知道要继承哪个构造函数,必须明确的使用super()关键字来描述。所以一般为了避免这种错误的发生,在有带多
个构造函数的类里面都会写一个不带参数的构造函数。