您的位置:首页 > 编程语言 > Java开发

Java之访问子类对象的实例变量

2016-05-24 17:01 465 查看
子类的方法可以访问父类的实例变量,这是因为子类继承父类就会获得父类的成员变量和方法。

父类的方法不能访问子类的实例变量,父类无从知道它将被哪个子类继承,它的子类将会增加怎样的成员变量。

Java对象不是由构造器创建的,只是负责对Java对象实例变量执行初始化。在执行构造器之前,该对象所占的内存已经被分配下来,这些内存里的值默认是空值。基本数据类型的默认值为0或false,引用类型的变量的默认值为null。

下面我们用例子来说明:

<pre name="code" class="java"><span style="font-size:14px;">//父类
public class Base {

private int i=2;
public Base(){
System.out.println("Base 构造器111:"+i);
this.display();
System.out.println("Base 构造器:"+i);
}
public void display() {
System.out.println("Base"+i);
}
}
//继承Base的子类
public class Derived extends Base{

private int i=22;

public Derived() {
// TODO Auto-generated constructor stub
System.out.println("Derived构造器:"+i);
i=222;
System.out.println("Derivedfangfa:"+i);
}
public void display() {
System.out.println("Derived方法:"+i);
}
}
测试:
public static void main(String[] args) {
// TODO Auto-generated method stub
new Derived(); //1
}
结果:
Base 构造器111:2
Derived方法:0
Base 构造器:2
Derived构造器:22
Derivedfangfa:222
运行该程序会发现输出的值为0,并不是2,22或222。</span>



运行该程序会发现输出的值为0,并不是2,22或222。

我们从内存分配的角度来分析程序的输出结果。
1.当程序在创建Derived对象的时候,系统开始为这个Derived对象分配内存空间。

Derived对象分配两块内存,分别用于存放Derived对象的两个i实例变量,其中一个属于Base类定义的I实例变量,另一个属于Derived类定义的i实例变量,此时这两个i实例的值都为0;
程序在执行Derived类之前会隐式调用父类的构造器,(也就是咱们在父类构造器文章中提到过的三点调用父类哪个构造器的执行顺序,不清楚者请移步《父类构造器》文章进行观看)。
表面上看Base类的构造器内只有一行代码
this.display(),

但是由于定义i实例变量时指定了初始值,编译器经过处理后,其实应该包含两行代码
i=2;
this.display();

(构造器是进行初始化值的!!!)
当this在构造器中时,this代表正在初始化的对象。从源码上看,此时的this位于Base()构造器内,但是这些代码实际放在了Derived类中执行,是Derived构造器隐式调用了Base()构造器的代码。
当变量的编译时和运行时类型不同时,通过该变量访问它引用的对象的实例变量时,该实例变量的值由声明该变量的类型决定。但通过该变量调用它引用的对象的实例方法时,该方法行为将由它实际所引用的对象来决定。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java