Java基本注解分析,为什么要使用@Override
2016-03-21 19:04
531 查看
@Override
标注在子类方法中,表示此方法是覆盖父类的重载方法,具有强制性,即如果父类没有此方法,则会编译出错。那它到底有什么用呢?让我们来看这一需求场景:假如我们利用面向对象的多态特性特性编程,有子类Sa,Sb继承自父类S.我们需要在子类Sa,Sb各自拓展父类S的speak方法,然后根据业务逻辑,通过A的引用来调用Sa,Sb的重载方法speak。示例代码如下所示:
/*--------------------定义父类A--------------------*/ public class A { public void speak(String city){ System.out.println("I'm A,I am not from " + city); } } /*--------------------定义子类Sa--------------------*/ public class Sa extends A{ public void spak(String city){ System.out.println("I'm Sa,I am from " + city); } } /*--------------------定义子类Sb-------------------*/ public class Sb extends A{ public void speak(String city){ System.out.println("I'm Sb,I am from " + city); } } /*--------------------调用测试方法-------------------*/ public static void main(String args[]){ int i = 0; A a = null; if(i == 0){//模拟满足业务条件1 System.out.print("业务逻辑1执行:"); a = new Sa(); a.speak("广东"); } if(++ i == 1){//模拟满足业务条件2 System.out.print("业务逻辑2执行:"); a = new Sb(); a.speak("湖北"); } } /*--------------------控制台打印-------------------*/ /* 业务逻辑1执行:I'm Sa,I am from 广东 业务逻辑2执行:I'm Sb,I am from 湖北 */
这里是我们业务中,想要的结果,但如果我们不小心把咱们的Sb类中的speak方法写错成了spek,或将传入参数类型、数量写错等(即不能成功重载),如下所示:
/*--------------------speak方法写错成了spek-------------------*/ public class Sb extends A{ public void spek(String city){ System.out.println("I'm Sb,I am from " + city); } } /*--------------------speak方法参数类型出错-------------------*/ public class Sb extends A{ public void spek(int city){ System.out.println("I'm Sb,I am from " + city); } } /*--------------------speak方法参数个数出错-------------------*/ public class Sb extends A{ public void spek(String city,String province){ System.out.println("I'm Sb,I am from " + city); } } /*--------------对于以上三种情况,控制台都会打印-------------------*/ /* 业务逻辑1执行:I'm Sa,I am from 广东 业务逻辑2执行:I'm A,I am not from 湖北 */
但如果我们在Sb的speak方法上添加注解@Override,则会出现编译异常如:The method speak(int) of type Sb must override or implement a supertype method
从上面我们能够看到,对子类的重载标注@Override是良好的编程习惯,否则在大规模的项目中,我们万一不小心出现这种细节错误,可能会为后期排错带来巨大障碍。
除了Override,还有另外两种最基本的注解:
@Deprecated
它用来标示某个类或其方法、变量等已过期,如果我们在其他类中调用标注了@deprecated的类或方法变量,将会引起编译器的警告@SuppressWarnings
它用于取消编译器的警告,标注了此注解的元素会有向下传递的效果,比如在类级别标注了注解,则在该类的所有方法中也会取消同类的编译器警告。相关文章推荐
- 基于CXF Java 搭建Web Service (Restful Web Service与基于SOAP的Web Service混合方案)
- Java内存管理与垃圾回收
- myeclipse 自定义xml模板,供新建xml文件时自动导入 (转)
- Spring3第二天
- thrift的TTransport连接池注意事项[Java版本说明]
- Spring MVC返回对象JSON
- Java泛型简明教程
- Java第二次作业
- Java虚拟机类加载机制
- 给eclipse 安装spring ide插件
- JAVA反射详解
- (多线程)ProducerCustomerJDK_5
- 浅谈java设计模式--策略者模式
- java int 与 integer的区别
- lombok eclipse 提示 generating getters and setters failed 错误解决方案
- 浅谈java字节流和字符流对文件的操作
- JAVAWEB Session 总结
- java连接池的maxIdle该如何配置
- java并发-怎么理解Condition
- 使用Intellij IEDA创建第一个springmvc例子