1.重载与重写的心得(*java中不能够存在子类和父类中存在方法名和参数相同就返回值类型不同的重载)
重写的规则:
A、重写规则之一:
重写方法不能比被重写方法限制有更严格的访问级别。(不能从public到private)
B、重写规则之二:
参数列表必须与被重写方法的相同。
C、重写规则之三:
返回类型必须与被重写方法的返回类型相同。(重写的返回值类型也可以是父子类关系)
D、重写规则之四:
重写方法不能抛出新的异常或者比被重写方法声明的检查异常更广的检查异常。但是可以抛出更少,更有限或者不抛出异常。
重载的规则:
指的是一个类中的同名方法,参数列表不同,返回值可能也不同。(严格意义上的子类与父类的重载也算是同一类中,因为子类继承了父类中的方法)
Java编译时类型与运行时类型以及重载和重写方法选择:
首先来看看Java中的编译时类型与运行时类型。编译时类型由声明该变量时使用的类型决定(也称静态类型)(前面的类型,也称父类引用指向子类对象),运行时类型由实际赋给该变量的对象决定.如果编译时类型和运行时类型不一致,
会出现所谓的多态。因为子类其实是一种特殊的父类,因此java允许把一个子类对象直接赋值给一个父类引用变量,无须任何类型转换,或者被称为向上转型,由系统自动完成。
引用变量在编译阶段只能调用其编译时类型所具有的方法,但运行时则执行它运行时类型所具有的方法,因此,编写Java代码时,引用变量只能调用声明该变量所用类里包含的方法。
与方法不同的是,对象的属性则不具备多态性。通过引用变量来访问其包含的实例属性时,系统总是试图访问它编译时类所定义的属性,而不是它运行时所定义的属性。
对于代码:(person就是一个引用变量),也就是说person对象不能调用student对象里独有的方法(非继承自Person对象的)和Student对象里的属性,
Person person = new Student();
将生成变量person,该变量的编译时类型是Person,而运行时类型是Student。
对于重载(overloaded),调用方法的选择是在编译时确定的,是静态选择的;而对于覆盖(overridden)方法的选择是动态的,在运行时确定的,选择的依据是被调用方法所在对象的运行时类型。
关于java 程序编译和运行过程
Java程序从源文件创建到程序运行要经过两大步骤:
一、源文件由编译器编译成字节码(ByteCode) 编译阶段被JVM的java编辑器编译成.class文件
二.java类运行的过程大概分为两个步骤:(1)类的加载 (2)类的执行。需要说明的一点的是:JVM主要在程序第一次运行时主动使用类的,才会加载且只加载一次