注解(也叫元數(shù)據(jù)),在代碼中添加信息提空一種形式化的方式,以便在稍后某個(gè)時(shí)刻非常方便地使用這些數(shù)據(jù)
內(nèi)置注解:
java.lang中的注解:
@Dverride:表示覆蓋父類中的方法;
@Deprecated:如果程序使用了注解為它的元素,那么編譯器會(huì)發(fā)出警告信息;
@SupperessWarnings:關(guān)閉不當(dāng)?shù)木幾g器警告信息;
元注解:
@Target:表示該注解可以用于什么地方。
可能的ElementType參數(shù)包括:
CONSTRUCTOR:構(gòu)造器的申明
FIELD:域生命(包括enum實(shí)例)
LOCAL_VARLABLE:局部變量聲明
METHOD:方法聲明
PACKAGE:包聲明
PARAMETER:參數(shù)聲明
TYPE:類、接口(包括注解類型)或 enum聲明
@Retention:表示需要在什么級(jí)別保存該注解信息。
可選的RetentionPolicy參數(shù)包括:
SOURCE:注解將被變異器丟棄
CLASS:注解在class文家中可用,但會(huì)被vm丟棄
RUNTIME:VM將在運(yùn)行期也保留注解,因此可以通過反射機(jī)制讀取注解信息
@Documented:此注解包含在javadoc中
@inherited:允許子類繼承父類中的注解
注解元素:
所有基本類型(int,float,boolean等)
String
Class
enum
Annotation
以上類型的數(shù)組
注:不允許使用任何包裝類型,使用自動(dòng)打包可突破限制。注解可以嵌套注解
創(chuàng)建注解:
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編程思想讀書筆記