java.lang.reflect.Method.getDeclaredAnnotations()
方法返回該元素上直接存在的所有注釋。 與此介面中的其他方法不同,此方法忽略了繼承的注釋(如果此元素上沒有注釋,則返回長度為零的數組)。此方法的調用者可以自由修改返回的數組; 它將對返回給其他調用者的數組沒有影響。
聲明
以下是java.lang.reflect.Method.getDeclaredAnnotations()
方法的聲明。
public Annotation[] getDeclaredAnnotations()
參數
- NA
返回值
- 如果存在於此元素,則返回該元素注釋指定的注釋類型,否則返回為
null
。
異常
- NA
以下示例顯示java.lang.reflect.Method.getDeclaredAnnotations()
方法的用法。
import java.lang.annotation.Annotation;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.reflect.Method;
public class MethodDemo {
public static void main(String[] args) {
Method[] methods = SampleClass.class.getMethods();
Annotation[] annotations = methods[0].getDeclaredAnnotations();
for(Annotation annotation : annotations){
if(annotation instanceof CustomAnnotation){
CustomAnnotation customAnnotation = (CustomAnnotation) annotation;
System.out.println("name: " + customAnnotation.name());
System.out.println("value: " + customAnnotation.value());
}
}
}
}
@CustomAnnotation(name="SampleClass", value = "Sample Class Annotation")
class SampleClass {
private String sampleField;
@CustomAnnotation(name="getSampleMethod", value = "Sample Method Annotation")
public String getSampleField() {
return sampleField;
}
public void setSampleField(String sampleField) {
this.sampleField = sampleField;
}
}
@Retention(RetentionPolicy.RUNTIME)
@interface CustomAnnotation {
public String name();
public String value();
}
讓我們編譯並運行上面的程式,這將產生以下結果 -
name: getSampleMethod
value: Sample Method Annotation