注解
1,什么是注解:
-
不是程序本身 , 可以对程序作出解释.(这一点和注释(comment)没什么区别)
-
可以被其他程序(比如:编译器等)读取.
-
格式:@SuppressWarnings(value=“unchecked”)
-
可以通过反射机制实现对这些元数据的访问
2,内置注解:
- @Override
- @Deprecated
- @SuppressWarnings
- @SuppressWarnings(“all”)
- @SuppressWarnings(“unchecked”)
- @SuppressWarnings(value={“unchecked”,“deprecation”})
3,元注解
作用:负责注解其他注解。
这些类型和它们所支持的类在java.lang.annotation包中可以找到
- @Target : 用于描述注解的使用范围(即:被描述的注解可以用在什么地方)
- @Retention : 表示需要在什么级别保存该注释信息 , 用于描述注解的生命周期(SOURCE < CLASS < RUNTIME)
- @Document:说明该注解将被包含在javadoc中
- @Inherited:说明子类可以继承父类中的该注解
@Target : //用来说明该注解可以被声明在那些元素之前。
ElementType.TYPE://说明该注解只能被声明在一个类前。
ElementType.FIELD://字段
ElementType.METHOD://方法
ElementType.PARAMETER://方法参数
ElementType.CONSTRUCTOR://构造方法
ElementType.LOCAL_VARIABLE://局部变量
ElementType.ANNOTATION_TYPE://注解类型
ElementType.PACKAGE://包
@Retention ://用来说明该注解类的生命周期。它有以下三个参数:
RetentionPolicy.SOURCE : //注解只保留在源文件中
RetentionPolicy.CLASS : //注解保留在class文件中,在加载到JVM虚拟机时丢弃
//常用
RetentionPolicy.RUNTIME : //注解保留在程序运行期间,此时可以通过反射获得定义在某个类上的所有注解。
4,自定义注解
使用 @interface自定义注解时 , 自动继承了java.lang.annotation.Annotation接口
分析 :
- @ interface用来声明一个注解 , 格式 : public @ interface 注解名 { 定义内容 }
- 其中的每一个方法实际上是声明了一个配置参数.
- 方法的名称就是参数的名称.
- 返回值类型就是参数的类型 ( 返回值只能是:基本类型,Class , String , enum ).
- 可以通过default来声明参数的默认值
- 如果只有一个参数成员 , 一般参数名为value
- 注解元素必须要有值 , 我们定义注解元素时 , 经常使用空字符串,0作为默认值 .
//定义一个注解
@Target(value = {ElementType.METHOD,ElementType.TYPE})
@Retention(value = RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface MyAnnotation{
//测试作用域 , 了解@Retention的概念
}
//测试自定义注解
public class Test3 {
//显示定义值 / 不显示值就是默认值
@MyAnnotation2(age = 18,name = "马冬梅",id = 001,schools = {"华南"})
public void test() {}
//只有一个参数, 默认名字一般是value.使用可省略不写
@MyAnnotation3("aaa")
public void test2(){}
}
@Target(value = {ElementType.METHOD})
@Retention(value = RetentionPolicy.RUNTIME)
@interface MyAnnotation2{
//参数类型 , 参数名
String name() default "";
int age() default 0;
int id() default -1; //String indexOf("abc") -1 , 不存在,找不到
String[] schools() default {"school A","school B"};
}
@Target(value = {ElementType.METHOD})
@Retention(value = RetentionPolicy.RUNTIME)
@interface MyAnnotation3{
// 参数类型 参数名称
String value();
}