动手动脑___11.07

一、为什么子类的构造方法在运行之前,必须调用父类的构造方法?能不能反过来?为什么不能反过来?

   构造函数(constructor)是一种特殊的方法 。主要用来在创建对象时初始化对象, 即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中 。特别的一个类可以有多个构造函数 ,可根据其参数个数的不同或参数类型的不同来区分它们 即构造函数的重载。构造函数的功能主要用于在类的对象创建时定义初始化的状态。构造一个对象,先调用其构造方法,来初始化其成员函数和成员变量。子类拥有父的成员变量和成员方法,如果不调用,则从父类继承而来的成员变量和成员方法得不到正确的初始化。不能反过来调用也是这个原因,因为父类根本不知道子类有神魔变量而且这样一来子类也得不到初始化的父类变量,导致程序运行出错!

二、请自行编写代码测试以下特性:在子类中,若要调用父类中被覆盖的方法,可以使用super关键字。

 

class Father
{
       public void multiplication(double a,double b)
       {
              System.out.println("父类的函数:"+a+"*"+b+"="+a*b);
       }
}
class Me extends Father
{
       public void multiplication(double a,double b)
       {
super.multiplication(a+1, b+2); System.out.println("我的函数:"+a+"*"+b+"="+a*b); } } public class TestInherit { public static void main(String[] args) { Me a=new Me(); a.multiplication(1,1.2); } }

 

  

 

 三、下列语句哪一个将引起编译错误?为什么?哪一个会引起运行时错误?为什么?

   m=d;

  d=m;

  d=(Dog)m;

   d=c;

   c=(Cat)m;

   "d=m","d=c"会出现编译错误,因为没有对M强制类型转化。d=c错误是因为d 和c类型不同导致错误。

四、运行以下测试代码

  

1. 左边的程序运行结果是什么?

Parent.printValue(),myValue=100
Child.printValue(),myValue=200
Child.printValue(),myValue=200
Child.printValue(),myValue=200
Child.printValue(),myValue=201

2. 你如何解释会得到这样的输出?

父类的字段被隐藏。

 

3. 计算机是不会出错的,之所以得 到这样的运行结果也是有原因的, 那么从这些运行结果中,你能总 结出Java的哪些语法特性?

当子类与父类拥有一样的方法,并且让一个父类变量引用一个子类对象时,对象是子类型的,它就调用子类型的方法,是父类型的,它就调用父类型的方法。

如果子类与父类有相同的字段,则子类中的字段会代替或隐藏父类的字段,子类方法中访问的是子类中的字段(而不是父类中的字段)。如果子类方法确实想访问父类中被隐藏的同名字段,可以用super关键字来访问它。 如果子类被当作父类使用,则通过子类访问的字段是父类的!

 

posted @ 2017-11-09 19:44  浪花98  阅读(146)  评论(0编辑  收藏  举报