注解和反射
注解(Annotation):
Annotation是从jdk5.0开始引入的新技术
Annotation是的作用:
1.不是程序本身,可以对程序做出解释(这一点和注释comment)没有区别)
2.可以被其他程序(比如:编译器等)读取
Annotation的格式:
1.注解是以“@注释名”在代码中存在的,还可以添加一些参数值,例如:@SuppressWarning(value="unchecked")
Annotation在哪里使用?
1.可以附加在package,class,method,field等上面,相当于给他们添加了额外的辅助信息,
我们可以通过反射机制编程实现对这些元数据的访问
内置注解:
@Override:定义在java.lang.Override中,此注解只适用于修辞方法,表示一个方法声明打算重写超类中的另一个方法声明。
@Deprecated:定义在java.lang.Deprecated中,此注解可以用于修辞方法,属性,类,表示不鼓励程序员使用这样的元素,通常是因为它很危险或者存在更好的选择。
@SuppressWarning:定义在java.lang.SuppressWarnings中,用来抑制编译时的警告信息。
与前两个注解不同的是,你需要添加一个参数才能正确使用,这些参数都是已经定义好的。
参数:"all","unchecked","deprecation"
@SuppressWarning("all")
@SuppressWarning("unchecked")
@SuppressWarning(value={"unchecked","deprecation"})
...
元注解:
元注解的作用就是负责注解其他注解,java定义了4个标准的meta-annotation类型,他们被用来 提供对其他annotation类型作说明;
这些类型和它们支持的类在java.lang.annotation包中可以找到 (@Target,@Retention,@Documented,@Inherited)
@Target:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)
@Retention:表示需要在什么级别保持该注释信息,用于描述注解的生命周期
(source<class<runtime)
@Documented:说明该注解被包含在javadoc中
@Inherited:说明子类可以继承父类中的该注解
自定义注解
使用@interface自定义注解时,自动继承了java.lang.annotation
public @interface 注解名{定义内容}