之前给大家讲过java final修饰符final修饰变量方面的知识,那么下面要继续给大家讲到的就是final修饰方法方面的知识,一起来了解一下吧。
final修饰的方法不能被重写,假如因为一些原因,不希望子类重写父类的某个方法,那么就可以使用final修饰这个方法。
Java提供的Object类里就有一个final方法 getClass(),因为Java不希望任何类重写这个方法,所以使用final将这个方法密封起来。
可是对于这个类提供的toString()和equals()方法,都允许子类重写,所以,没有使用final修饰它们。
下面的话,试图重写final方法,就会引起编译错误。
public class FinalMethodTest { public final void test() {} } class Sub extends FinalMethodTest { // 下面方法定义将出现编译错误,不能重写final方法 public void test() {} }
上面的程序当中,程序中父类是FinalMethodTest,这个类里定义的test()方法是一个final方法,假如,其子类试图重写这个方法,那么就会引起编译错误。
对于一个private方法,由于它仅在当前类中可见,它的子类不能够访问这个方法,所以子类不能够重写这个方法——假如,子类当中定义一个和父类private方法有相同方法名、相同形参列表、相同返回值类型的方法,也不是方法重写,只是重新定义了一个新方法,所以的话,即便是使用final修饰一个private访问权限的方法,依然可以在其子类中定义和这个方法具有相同方法名、相同形参列表、相同返回值类型的方法。
下面的程序示范了怎样在子类当中重写父类的private final方法。
public class PrivateFinalMethodTest { private final void test() {} } class Sub extends PrivateFinalMethodTest { // 下面的方法定义不会出现问题 public void test() {} }
上面程序没有任何问题,虽然子类和父类同样包含了同名的void test()方法,可是,子类并不是重写父类的方法,所以,即便父类的void test()方法使用了final修饰,子类当中任然能够定义void test()方法。
final修饰的方法仅仅是不能被重写,并不是不可以被重载,所以下面的程序是完全没有问题的。
public class FinalOverload { // final 修饰的方法只是不能被重写,完全可以被重载 public final void test() {} public final void test(String arg) {} }
以上的知识你都了解了吗?更多相关java基础知识,请继续来本站进行了解吧。
推荐阅读: