Java.lang.getDeclaredAnnotations() 方法

描述

java.lang.Package.getDeclaredAnnotations() 方法返回直接存在于该元素上的所有注释。 与此接口中的其他方法不同,此方法忽略继承的注解。 (如果此元素上没有直接存在注释,则返回长度为零的数组。)此方法的调用者可以自由修改返回的数组; 它不会影响返回给其他调用者的数组。


声明

以下是 java.lang.Package.getDeclaredAnnotations() 方法的声明。

public Annotation[] getDeclaredAnnotations()

参数

NA


返回值

此方法返回此元素上直接存在的所有注释


异常

NA


示例

下面的例子展示了 lang.Object.getDeclaredAnnotations() 方法的使用。

package com.tutorialspoint;

import java.lang.annotation.Annotation;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.reflect.Method;

// declare a new annotation
@Retention(RetentionPolicy.RUNTIME)
@interface Demo {
   String str();
   int val();
}

public class PackageDemo {

   // set values for the annotation
   @Demo(str = "Demo Annotation", val = 100)
   // a method to call in the main
   public static void example() {
      PackageDemo ob = new PackageDemo();

      try {
         Class c = ob.getClass();

         // get the method example
         Method m = c.getMethod("example");

         // get the annotations
         Annotation[] annotation = m.getDeclaredAnnotations();

         // print the annotation
         for (int i = 0; i < annotation.length; i++) {
            System.out.println(annotation[i]);
         }
      } catch (NoSuchMethodException exc) {
         exc.printStackTrace();
      }
   }
   public static void main(String args[]) {
      example();
   }
}

让我们编译并运行上面的程序,这将产生下面的结果 −

@com.tutorialspoint.Demo(str=Demo Annotation, val=100)