刚学习继承的时候,总是会有这样的疑问。
子类继承父类时,会继承所有的非私有的属性和方法。那么在用set方法修改父类的私有属性时,怎么没有报空指针异常呢?
后来仔细想过这个问题,既然没有报空指针,那么在内存里这个属性一定是存在的。那么问题又来了,既然都在问题为什么又不能访问呢。百度了一下,原来在实例化子类的过程中,有一些有趣的东西。都知道在实例化子类之前,会先调用父类的构造方法。此时,就可以把子类的内存看做两部分,一部分是父类,一部分是子类其本身。super和this就分别指向这两部分,this的权限相比于super要大一些,super只能访问属于父类的那块区域,而this除了能访问子类本身的那部分区域外,还能访问super中那些没有被private修饰的东西。这儿还有个有趣的东西,就是重写,在父类变量引用子类实例的时候,为什么不能调用子类特有的方法的原因,通过上面的原因就很显而易见了,那么为什么此时调父类的方法却访问的是子类重写后的方法呢。原来,尽管变量是一个父类的对象,但实例出来的对象却是子类的,在访问方法时,会先扫描this指向的区域,如果在其中找到了就停止扫描,然后调用扫描到的方法,如果没有找到那么就会扫描super执行的区域,如果找到就停止,然后执行,如果没有找到就抛出异常。
才疏学浅,若有不对,请留言指正。