java 构造函数 重载 递归调用

1)有人写了个很好的初始化属性的构造函数,而你仅仅想要在其中添加另一些自己新建属性的初始化,这样在一个构造函数中调用另外一个构造函数,可以避免重复的代码量,减少工作量;

2)在一个构造函数中调用另外一个构造函数的时候应该用的是同一块内存空间,在默认的构造函数中先初始化变量,调用另一个的时候覆写已经初始化的变量的值;

3)整个调用的过程和递归调用函数有点类似,不断充气球,直到整个气球膨胀起来,不断的深层递进,遇到停止标记,逐层的跳出来。

     写了段代码,解释我上面的叙述:

复制代码
 1 class JavanTiger {
 2     int age;      // 年龄
 3     int hight;    // 身体高度
 4 
 5     public JavanTiger() {
 6         print();
 7         this.age=2;   //这里初始化 age 的值 ,但递归返回的时候,这个值会被覆写
 8     }
 9     
10     public JavanTiger(int age) {
11         this();      // 调用自己的第一个构造函数,下面的两个语句数不执行的
12         this.age = age;
13         print();
14     }
15 
16     public JavanTiger(int age, int hight) {
17         this(age);   // 调用自己第二个构造函数  ,下面的两个语句数不执行的
18         this.hight = hight;
19         print();
20     }
21 
22     public void print() {  //打印函数
23         System.out.println("I'am a " + age + "岁 " + hight + "尺高 tiger!");
24     }
25     public static void main(String[] args) {
26         new JavanTiger(3,3);
27     }
28 }
29 //output
30 //I'am a 0岁 0尺高 tiger!
31 //I'am a 3岁 0尺高 tiger!
32 //I'am a 3岁 3尺高 tiger!  
      个人理解就是这样了,可能里面还有问题,比如构造函数递归调用和程序函数递归调用的机制是否似乎相同的?构造函数同对象一起产生,也就是同时会分配内存空间出来,那门这样的递归调用会不会打乱分配内存的顺序?希望看到的大牛们拍板,给个最好的解释。

     

你可能感兴趣的:(java 构造函数 重载 递归调用)