无论是在netBeans还是在eclipse开发环境中,写java代码的时候经常会碰到@Override,那么@Override具体是什么呢?
@Override是伪代码,表示重写(当然不写也可以),不过写上有如下好处:
1、可以当注释用,方便阅读
2、编译器可以给你验证@Override下面的方法名是否是你父类中所有的,如果没有则报错
比如你如果没写@Override而你下面的方法名又写错了,这时你的编译器是可以通过的(它以为这个方法是你的子类中自己增加的方法)。
如下例所示:
class Fu{ private int a = 1; void print() { System.out.println("父类"); }}class Zi extends Fu{ @Override void prin()//子类方法名与父类不同,编译会出错 { System.out.println("子类"); }}public class Test{ public static void main(String[] args) { new Zi().prin(); }}
因此,在我们手工复写父类的方法时,容易把方法的参数记错或方法名写错,如果此时不加@Override的话,编辑器就不会提示。
以下引自:
《Thinking in java》的作者Bruce在讨论这个问题的时候,提到了一个问题就是override私有的方法的例子:
现在我们向Fu类中添加一个私有方法,而在Zi中尝试复写
结果编译器会提示错误,这是一个非常低级的错误,但是有时候恰恰就不会被我们发现:那就是试着复写私有方法,但是当我们去掉Override标签的时候,编译器是不会报错的,而且可以执行。
其实Zi中的你所谓复写的print只是一个针对于Zi本身的私有方法。完全是一个新的方法。
这就引出了一个问题,何为复写?
在面向对象中,只有接口和共有方法,继承方法才有复写,私有方法不可以复写,但是又想了一下,才明白:不是不可以复写,而是根本就不存在复写私有方法的概念!
这正是面向对象设计的初衷,私有方法本身就是为了封装在类内部,不希望别人来更改或者外部引用的,看到这里,忽然觉得,java设计的还真是不错,感觉到了思想和实现的统一。
以前总觉得override标签可有可无,但没想到会引出这么多的问题,于是乎得到一个启示:认真思考每一个语法细节的意义,思行合一。