注解的作用:
1)不是程序本身,可以对程序作出解释。(类似注释)
2)可以被其他程序(比如编译器)读取。(注解信息处理流程,是注解和注释的重大区别,如果没有注解信息处理流程,则注解毫无意义)
注解的格式:
注解是以“@注释名”在代码中存在,还可以添加一些参数值,例如@Suppress Warnings(value = “unchecked”)。
注解的使用:
可以附加在package,class,method,field等上面,相当于给他们添加了额外的辅助信息,我们可以通过反射机制编程实现对这些元素的访问。
内置的注解:
1)@Override :标识方法是重写的方法
2)@Deprecated :标识的方法不建议使用
3)@Suppress Warining :用来抑制编译时的警告信息
@suppress Warining 需要提供参数才能正常使用,这些参数都是已经定义好的,我们只需要选择就可以了。
参数: 说明:
deprecation 使用了过时的类或者方法的警告
unchecked 执行了未检查的转换时的警告,如使用集合未指定泛型
fallthrough 当在使用switch语句使用时发生穿透
path 在类路径、源文件路径等中又不存在路径的警告
serial 当在可序列化的类上缺少serialVersionUID定义时的警告
finally 任何finally子句不能完成时的警告
all 关于以上所有情况的警告、
举例:
@Suppress Warnings(“unchecked”)
@Suppress Warnings(value={“unchecked”,“deprecation”})
@Target(ElementType.METHOD) //ElementType 是一个枚举类型 @Target用于描述注解的使用范围
@Retention(RetentionPolicy.RUNTIME) //表示在运行时保存该注解信息 @Retention用于描述注解的生命周期
public @interface MyAnnotation {
String stuName() default "";
int age() default 0;
String [] ch() default {"a","b"};
}
@Target({ElementType.TYPE,ElementType.METHOD}) //ElementType 是一个枚举类型 @Target用于描述注解的使用范围
@Retention(RetentionPolicy.RUNTIME) //表示在运行时保存该注解信息 @Retention用于描述注解的生命周期
public @interface MyAnnotation2 {
String value();
}
下面是测试类:
//@MyAnnotation 报错 ,因为该注解声明了只能应用在方法上
@MyAnnotation2(value = "aaa") //不报错,因为该注解声明了可以用在TYPE上(Class)
public class Test {
@MyAnnotation(stuName="张三")
void show() {
}
@MyAnnotation(stuName="李四",age=23,ch= {"a","b"})
public void method() {
}
}