为何学习注解?java
学习注解有什么好处?程序员
学完能作什么?spring
答:1. 可以读懂别人写的代码,特别是框架相关的代码;数据库
2. 让编程更加简洁,代码更加清晰;编程
3. 让别人高看一眼。mybatis
spring、mybatis使用了大量的注解,会用注解不是目的,会使用自定义注解才是亮点。框架
java注解在java1.5版本引入。ide
Java提供了一种原程序中的元素关联任何信息和任何元数据的途径和方法。函数
@Override 表示覆盖或重写父类的方法;学习
@Deprecated 表示该方法已通过时了。(当方法或是类上面有@Deprecated注解时,说明该方法或是类都已通过期不能再用,但不影响之前项目使用,提醒你新替代待的方法或是类。若是程序员不当心使用了它的元素,那么编译器会发出警告信息。)
@SuppressWarnings 表示忽略指定警告,好比@Suppvisewarnings("Deprecation")
好比下面的例子:
person接口:
1 public interface Person { 2 public String name(); 3 4 public int age(); 5 6 /*@Deprecated 表示该方法已通过时了*/ 7 @Deprecated 8 public void sing(); 9 /*注: 10 当方法或是类上面有@Deprecated注解时, 11 说明该方法或是类都已通过期不能再用, 12 但不影响之前项目使用,提醒你新替代待的方法或是类 13 */ 14 }
child实现类:
1 public class Child implements Person { 2 3 /*@Override 表示覆盖或重写父类的方法*/ 4 @Override 5 public String name() { 6 // TODO Auto-generated method stub 7 return null; 8 } 9 10 11 @Override 12 public int age() { 13 // TODO Auto-generated method stub 14 return 0; 15 } 16 17 18 @Override 19 public void sing() { 20 // TODO Auto-generated method stub 21 22 }
测试类:
1 public class Test { 2 /*@SuppressWarnings 表示忽略指定警告,好比@Suppvisewarnings("Deprecation")*/ 3 @SuppressWarnings("deprecation") 4 public void sing(){ 5 Person p=new Child(); 6 7 p.sing(); 8 } 9 10 }
具体示例以下:
Autowired将成员变量自动注入进来
按运行机制(注解存在于程序的那个阶段)将注解分为三类:源码注解(只在源码存在)、编译注解(在class文件中也存在)、运行时注解(在运行阶段仍然起做用)
按照来源来分的话,有以下三类:
1:JDK自带的注解(Java目前只内置了三种标准注解:@Override、@Deprecated、@SuppressWarnings,以及四种元注解:@Target、@Retention、@Documented、@Inherited)
2:第三方的注解——这一类注解是咱们接触最多和做用最大的一类
3:自定义注解——也能够看做是咱们编写的注解,其余的都是他人编写注解
按照功能来分的,还有,元注解——注解的注解。
如今逐行分析:
@Target 是注解的做用域 :表示该注解能够用于一个类中的那些属性及方法上,若是做用域类型有多个用英文逗号分隔
下面是注解的做用域的列表:
@Retention:表示该注解的生命周期
注解按声明周期有个分类:
@Inherited:此注解是标识性的元注解,表示当前注解能够由子注解来继承
@Documented:表示生成javadoc的时候会包含注解
示例:
注解的定义看起来很像接口的定义,事实上,与其余任何Java接口同样,注解也将会编译成class文件。
定义注解时,会须要一些元注解(meta-annotation),如@Target和@Retention。@Target用来定义你的注解将用于什么地方(例如是一个方法或一个域)。@Retention用来定义该注解在哪个级别可用,在源代码(SOURCE)、类文件中(CLASS)或者运行时(RUNTIME)。
概念:经过反射获取类、函数或成员上运行时注解信息,从而实现动态控制程序运行的逻辑。
如:
使用forName()方法加载类,并使用getAnnotation(Description.class)检查该类是否带有@Description注解。
注解的继承只能做用在类上,方法上的注解不会被继承,Interface中的全部注解不会被继承。
具体示例:
Test测试类:
首先,考虑代码如何与数据库进行映射。
上面的Filter类与数据库表的结构很是类似。
对注解@Table 和@Column进行定义:
接下来考虑query()方法的实现:
运行结果:
此时须要对4.3部分改善一下:
运行结果:
改善后:
此时运行结果:
以上就基本完成了需求。
看咱们都学会了啥?