注解(Annotation):
从JDK5.0开始提供Annotation的功能,注解可以附加在
package,class,method,field等上面,相当于给他们添加额外的辅助消息。
我们可以通过,反射机制,对这些元数据进行访问。
如果没有外部解析工具,对其加以解析和处理的,则不会对代码产生任何影响。
annotation 可以从源文件,class文件,或者以在运行时反射的多种方式被读取。
SUN提供的原始注解:
@Override : 方法的重写(覆写)
@SuppressWarning : 用于通知java编译器禁止特定的编译警告
@Deprecated : 表示不鼓励程序员使用这样的元素,修饰已过时的方法
@Target : 元注解,说明注解可以出现在哪些地方
@Retention : 元注解,注解的生命周期,三种取值(SOURCE,CLASS,RUNTIME)
//指定多种情况禁止警告。 消除全部警告 "all"
@SuppressWarnings({ "unchecked", "unused","deprecation","serial" })
public class Student implements Serializable {
private String name;
}
自定义注解:
开发步骤:
1.定义注解
2.使用注解
3.得到注解的值
@Target(ElementType.TYPE) //使用在类上
@Retention(RetentionPolicy.RUNTIME) //运行时
public @interface Description { //定义注解
String value() default "xxx";
}
@Target(value=ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Name {
String name();//姓名
String job();//职务
}
//调用Description注解 default(默认)为:xxx 可以不写(***)
@Description
public class Employee {
@Name(name="jack",job="教员") //使用Name注解,填写name ,job 元素。
public void getEmployee(){
//.......
}
}
注解的应用:
定义注解:
@interface 关键字
每个方法声明定义为一个元素
方法声明不能包含有参数和throws子句
方法类型只能是:基本类型,String,Class,enums,
annotation,以及它们的数组。
方法可以定义缺省值
public @interface Description{
String value();
}