在Java中,重载是由静态类型确定的,在类加载的时候就可以确定,属于静态分派。而重写是是在运行时确定的,属于动态分配。动态分派由需方法表实现,虚方法表中存在着各个方法的实际入口地址。如果父类中的某个方法子类没有被重写,那么父类与子类的方法表中的方法地址相同,如果重写了,则子类方法表达地址指向重写后的地址。一般重写针对子类继承父类,重写父类的方法是通过动态绑定实现的,而重载是同一个方法名,但是参数类型或者个数不同子类重写父类某个方法时,二者参数列表和返回类型需要完全一致。如需调用父类中原有的方法。可用super关键字,该关键字会引用了当前类的父类,同时子类中该方法的访问权限不能小于父类的,重写的方法所抛出的异常与被重写的方法所抛出的异常要一致或是其子类。
关于静态分派与动态分派
静态分派 :所有依赖静态类型来定位方法执行版本的分派成为静态分派,发生在编译时期,典型**应用为方法重载。静态分派发生在编译阶段,因此确定静态分派的动作实际上不是由虚拟机来执行的。动态分派 :典型应用为重写,是一种动态的概念,向上转型后调用子类覆写的方法便是一个很好地说明动态分派的例子。就是说,我们在判断执行的方法是父类中的方法还是子类中覆盖的方法时;如果用静态类型来判断,那么无论怎么进行向上转型,都只会调用父类中的方法,但实际情况是,根据对父类实例化的子类的不同,调用的是不同于子类中覆写的方法,很明显,这里是要根据变量的实际类型来分派方法的执行版本的。但是实际类型的确定需要在程序运行时才能确定下来,这种在运行期根据实际类型确定方法执行版本的分派过程称为动态分派。动态分派的实现是在方法区中建立方法表。如果子类没有重写父类的方法,则子类虚方法表中该方法的入口地址与父类指向相同,否则子类方法表中的地址会替换为指向子类重写的方法的入口地址。