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