微×信×公×众×号:IT90s最前线
下面是一个java中的类继承代码实例,通过这个列子我们就可以明白继承过程中,成员变量和继承方法的区别
class Animal {
int weight = 2;
public void display (){
system.out.println (this.weight);
}
}
//声明一个类继承于动物类
class Dog extends Animal {
int weight = 20;
public void display (){
system.out.println (this.weight);
}
public class Test {
public void mian(String []args){
//1
Animal a = new Animal();
a.display();
//2
Dog b = new Dog ();
b.display();
//3
Animal c = new Dog ();
system.out.println(a.weight);
a.dispaly();
//4
Animal d = b;
system.out.println(d.weight);
d.display();
}
}
}
当该程序执行时,输出结果,1,2两处输出的都是在其类中的值,3,首先输出的是2,然后输出的20,这里就好和之前说的this一样,this代指的是当前执行期间的实例对象,当执行方法的时候调用的是当前存在的实例,而其实例变量则是该变量的声明类型。在这里便是如此,我们令Animal 实例 c等于一个Dog实例,所a.weight是其声明类型中的变量,也就是2,但是其调用的方法,则调用的是当前类型的,也就是会输出20,接下来就是令d等于之前的实例化对象,此时这两个变量所指向的内存都是一个Dog对象,当判断d==b时,也是true,但是当我们输出的时候,当调用实例变量的时候还是输出的是原类型的变量,而不是此时指向对象的变量的值,这也就是说明在我们创建的对象的内存中,我们存了两个值,一个是继承自父类的,一个是本身的,系统会根据 声明类型来自动的进行匹配,但是方法为什么就不是这样呢?问题来了
原因就是在继承过程中,编译器会将父类中的方法,变量转移到子类之中,但是当子类重写了父类的方法之后,就会将之前的方法覆盖掉,但是对实例变量来说就是不会出现这种问题,实例变量在内存中会出现两块内存,一块用来存储来自父类的方法,一部分用来存储子类的实例变量,所以说即使有相同的变量也是不会被覆盖掉的,但是对于方法来说只会存在一块内存区用来存储方法,一旦有相同的方法出现,父类的方法将无法移到子类之中。所以对于一个引用变量,当通过该变量访问实例变量的时候,访问的是声明类型的变量,但是调用的方法就是取决于其它实际引用对象的类型。
微×信×公×众×号:[IT90s最前线]