java中的注解

注解

注解相当于一个标记,加了注解就等于打上了某种标记,没加则等于没有某种标记,以后,javac编译器或开发工具盒其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事标记可以加载包,来,字段,方法的参数以及局部变量上,一个注解就相当于一个java类。

 

@Override  表示当前方法是覆盖父类的方法。

      @Deprecated  表示当前元素是不赞成使用的过时的。

      @SuppressWarnings 表示关闭一些不当的编译器警告信息。

@SuppressWarnings("deprecation")//不提示过时

自定义注解实例

package Test_annotation;   

import java.lang.annotation.Documented;   

import java.lang.annotation.Inherited;   

import java.lang.annotation.Retention;   

import java.lang.annotation.Target;   

import java.lang.annotation.ElementType;   

import java.lang.annotation.RetentionPolicy;   

  /*  

 * 元注解@Target,@Retention,@Documented,@Inherited  

 *   

 *     @Target 表示该注解用于什么地方,可能的 ElemenetType 参数包括:  

 *         ElemenetType.CONSTRUCTOR 构造器声明  

 *         ElemenetType.FIELD 域声明(包括 enum 实例)  

 *         ElemenetType.LOCAL_VARIABLE 局部变量声明  

 *         ElemenetType.METHOD 方法声明  

*         ElemenetType.PACKAGE 包声明  

 *         ElemenetType.PARAMETER 参数声明  

 *         ElemenetType.TYPE 类,接口(包括注解类型)或enum声明  

 *           

 *     @Retention 表示在什么级别保存该注解信息。可选的 RetentionPolicy 参数包括:  

 *         RetentionPolicy.SOURCE 注解将被编译器丢弃  

 *         RetentionPolicy.CLASS 注解在class文件中可用,但会被VM丢弃  

 *         RetentionPolicy.RUNTIME VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。  

 *           

 *     @Documented 将此注解包含在 javadoc 中  

 *       

 *     @Inherited 允许子类继承父类中的注解  

 *     

 */  

@Target(ElementType.METHOD)   

@Retention(RetentionPolicy.RUNTIME)   

@Documented  

@Inherited  

/*  

 * 定义注解 Test  

 * 注解中含有两个元素 id 和 description  

 * description 元素 有默认值 "no description"  

 */  

public @interface Test {   

    public int id();   

    public String description() default "no description";   

}  

package Test_annotation;

 

import java.lang.annotation.Documented;

import java.lang.annotation.Inherited;

import java.lang.annotation.Retention;

import java.lang.annotation.Target;

import java.lang.annotation.ElementType;

import java.lang.annotation.RetentionPolicy;

 

/*

 * 元注解@Target,@Retention,@Documented,@Inherited

 * 

 *     @Target 表示该注解用于什么地方,可能的 ElemenetType 参数包括:

 *         ElemenetType.CONSTRUCTOR 构造器声明

 *         ElemenetType.FIELD 域声明(包括 enum 实例)

 *         ElemenetType.LOCAL_VARIABLE 局部变量声明

 *         ElemenetType.METHOD 方法声明

 *         ElemenetType.PACKAGE 包声明

 *         ElemenetType.PARAMETER 参数声明

 *         ElemenetType.TYPE 类,接口(包括注解类型)或enum声明

 *         

 *     @Retention 表示在什么级别保存该注解信息。可选的 RetentionPolicy 参数包括:

 *         RetentionPolicy.SOURCE 注解将被编译器丢弃

 *         RetentionPolicy.CLASS 注解在class文件中可用,但会被VM丢弃

 *         RetentionPolicy.RUNTIME VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。

 *         

 *     @Documented 将此注解包含在 javadoc 

 *     

 *     @Inherited 允许子类继承父类中的注解

 *   

 */

@Target(ElementType.METHOD)

@Retention(RetentionPolicy.RUNTIME)

@Documented

@Inherited

/*

 * 定义注解 Test

 * 注解中含有两个元素 id 和 description

 * description 元素 有默认值 "no description"

 */

public @interface Test {

public int id();

public String description() default "no description";

}

    

下面是一个使用注解 和 解析注解的实例

package Test_annotation;   

import java.lang.reflect.Method;   

 

public class Test_1 {   

  /*  

     * 被注解的三个方法  

    */  

    @Test(id = 1, description = "hello method_1")   

   public void method_1() {   

    }   

  

   @Test(id = 2)   

    public void method_2() {   

   }   

 

  @Test(id = 3, description = "last method")   

   public void method_3() {   

   }   

  

   /*  

     * 解析注解,将Test_1类 所有被注解方法 的信息打印出来  

     */  

   public static void main(String[] args) {   

        Method[] methods = Test_1.class.getDeclaredMethods();   

        for (Method method : methods) {   

          /*  

             * 判断方法中是否有指定注解类型的注解  

           */  

            boolean hasAnnotation = method.isAnnotationPresent(Test.class);   

            if (hasAnnotation) {   

             /*  

                * 根据注解类型返回方法的指定类型注解  

               */  

                Test annotation = method.getAnnotation(Test.class);   

             System.out.println("Test( method = " + method.getName()   

                    + " , id = " + annotation.id() + " , description = "  

                       + annotation.description() + " )");   

         }   

     }   

    }   

  

}  

package Test_annotation;

 

import java.lang.reflect.Method;

 

public class Test_1 {

/*

 * 被注解的三个方法

 */

@Test(id = 1, description = "hello method_1")

public void method_1() {

}

 

@Test(id = 2)

public void method_2() {

}

 

@Test(id = 3, description = "last method")

public void method_3() {

}

 

/*

 * 解析注解,将Test_1类 所有被注解方法 的信息打印出来

 */

public static void main(String[] args) {

Method[] methods = Test_1.class.getDeclaredMethods();

for (Method method : methods) {

/*

 * 判断方法中是否有指定注解类型的注解

 */

boolean hasAnnotation = method.isAnnotationPresent(Test.class);

if (hasAnnotation) {

/*

 * 根据注解类型返回方法的指定类型注解

 */

Test annotation = method.getAnnotation(Test.class);

System.out.println("Test( method = " + method.getName()

+ " , id = " + annotation.id() + " , description = "

+ annotation.description() + " )");

}

}

}

 

}

   

输出结果如下:

    Test( method = method_1 , id = 1 , description = hello method_1 ) 

    Test( method = method_2 , id = 2 , description = no description ) 

    Test( method = method_3 , id = 3 , description = last method ) 

posted @ 2013-08-14 12:24  z智h慧  阅读(290)  评论(0编辑  收藏  举报