注解(也叫元数据),在代码中添加信息提空一种形式化的方式,以便在稍后某个时刻非常方便地使用这些数据
内置注解:
java.lang中的注解:
@Dverride:表示覆盖父类中的方法;
@Deprecated:如果程序使用了注解为它的元素,那么编译器会发出警告信息;
@SupperessWarnings:关闭不当的编译器警告信息;
元注解:
@Target:表示该注解可以用于什么地方。
可能的ElementType参数包括:
CONSTRUCTOR:构造器的申明
FIELD:域生命(包括enum实例)
LOCAL_VARLABLE:局部变量声明
METHOD:方法声明
PACKAGE:包声明
PARAMETER:参数声明
TYPE:类、接口(包括注解类型)或 enum声明
@Retention:表示需要在什么级别保存该注解信息。
可选的RetentionPolicy参数包括:
SOURCE:注解将被变异器丢弃
CLASS:注解在class文家中可用,但会被vm丢弃
RUNTIME:VM将在运行期也保留注解,因此可以通过反射机制读取注解信息
@Documented:此注解包含在javadoc中
@inherited:允许子类继承父类中的注解
注解元素:
所有基本类型(int,float,boolean等)
String
Class
enum
Annotation
以上类型的数组
注:不允许使用任何包装类型,使用自动打包可突破限制。注解可以嵌套注解
创建注解:
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface UseCase {
public int id();
public String description() default "no description";
}
使用注解:
public class PasswordUtils {
@UseCase(id = 47, description = "Passwords must conttain at least one numeric")
public boolean validatePassword(String password) {
return (password.matches("\\w*\\d\\w*"));
}
@UseCase(id = 48)
public String eccryptPassword(String password) {
return new StringBuilder(password).reverse().toString();// 取反
}
@UseCase(id = 49, description = "New password can't equal previously used ones")
public boolean checkForNewPassword(List<String> prevPasswords, String password) {
return !prevPasswords.contains(password);// 包含
}
}
编写注解处理器:
——Java编程思想读书笔记