您好,登錄后才能下訂單哦!
注解概念
注解是Java SE 5.0版本開始引入的概念,它是對java源代碼的說明,是一種元數據(描述數據的數據)。
注解和注釋的不同
注解分類
注解以@開頭,我們會在應用程序中見到各種各樣的注解,比如 @Autowired,@Service,@Controller,@Override,@Test,@Value 等等,按照來源劃分,可以分為 JDK的注解, 第三方的注解, 自定義注解。
JDK注解
JAVA 內置注解
第三方注解(各種框架注解)
請自行百度各個框架的注解詳解
自定義注解
使用元注解自己定義的注解
JDK中有一些元注解,主要有@Target,@Retention,@Document,@Inherited用來修飾注解。
表明該注解可以應用的java元素類型
表明該注解的生命周期
表明該注解標記的元素可以被Javadoc 或類似的工具文檔化
表明使用了@Inherited注解的注解,所標記的類的子類也會擁有這個注解
注解格式
/**
* 修飾符
@interface 注解名 {
* 注解元素的聲明1
* 注解元素的聲明2
* }
* 修飾符:訪問修飾符必須為public,不寫默認為pubic;
* 關鍵字:必須為
@interface;
* 注解名: 注解名稱為自定義注解的名稱,使用時還會用到;
* 注解類型元素:注解類型元素是注解中內容,可以理解成自定義接口的實現部分;
*/
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public
@interface MyTestAnnotation {
/**
* 注解的元素聲明的兩種形式
* type elementName();
* type elementName() default value;
*/
String value()
default
"test";
}
注解樣例
接下來我們以Spring中的 @Service 注解為例
@Target({ElementType
.TYPE})
// ElementType.TYPE 代表在注解上使用
@Retention(RetentionPolicy.RUNTIME)// RetentionPolicy.RUNTIME 代表運行時使用,可以通過反射獲取到
@Documented//包含在JavaDoc中
@Component//允許通過包掃描的方式自動檢測
public @interface Service {
/**
* The value may indicate a suggestion for a logical component name,
* to be turned into a Spring bean in case of an autodetected component.
* @return the suggested component name, if any (or empty String otherwise)
*/
@AliasFor(annotation = Component.class)
String value() default "";
}
@Annotation
JDK1.5有的,在rt.jar包下 java.lang.annotation包下,所有的注解默認繼承了Annotation接口,但是它本身不能定義注解。
package java.lang.annotation;
/**
* 所有的注解默認繼承了Annotation接口,但是它本身不能定義注解。
* The common interface extended by all annotation types. Note that an
* interface that manually extends this one does <i>not</i> define
* an annotation type. Also note that this interface does not itself
* define an annotation type.
*
* More information about annotation types can be found in section 9.6 of
* <cite>The Java? Language Specification</cite>.
*
* The {
@link java.lang.reflect.AnnotatedElement} interface discusses
* compatibility concerns when evolving an annotation type from being
* non-repeatable to being repeatable.
*
*
@author Josh Bloch
*
@since 1.5
*/
public
interface
Annotation {
.
.
.
}
第一步-定義自定義注解
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public
@interface MyTestAnnotation {
String value()
default
"test";
}
第二步-配置注解
@Data
@Builder
@MyTestAnnotation
public class MyBean {
private
String
name;
private
int
age;
}
第三步-利用反射解析注解
public
class
MyTest {
//isAnnotationPresent:判斷當前元素是否被指定注解修飾
//getAnnotation:返回指定的注解
//getAnnotations:返回所有的注解
public static void main(String[] args) {
try {
//獲取MyBean的Class對象
MyBean myBean = MyBean.builder().build();
Class clazz = myBean.getClass();
//判斷myBean對象上是否有MyTestAnnotation注解
if (clazz.isAnnotationPresent(MyTestAnnotation.class)) {
System.out.println("MyBean類上配置了MyTestAnnotation注解!");
//獲取該對象上MyTestAnnotation類型的注解
MyTestAnnotation myTestAnnotation = (MyTestAnnotation) clazz.getAnnotation(MyTestAnnotation.class);
System.out.println(myTestAnnotation.value());
} else {
System.out.println("MyBean類上沒有配置MyTestAnnotation注解!");
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
執行main方法,運行結果:
Connected to the target VM, address:
'127.0.0.1:62125', transport:
'socket'
MyBean類上配置了MyTestAnnotation注解!
test
Disconnected
from the target VM, address:
'127.0.0.1:62125', transport:
'socket'
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。