TA的每日心情  | 开心 2021-12-13 21:45 | 
|---|
 
  签到天数: 15 天 [LV.4]偶尔看看III  
 | 
 
| 
 
   
 直接上例子,新建java Project 
 
 1.新建Interface,建完在名字前加@,就成了自定义的注解 
  
- import java.lang.annotation.Documented;
 - import java.lang.annotation.ElementType;
 - import java.lang.annotation.Retention;
 - import java.lang.annotation.RetentionPolicy;
 - import java.lang.annotation.Target;
 - /**
 -  * 定义一个注解
 -  */
 - @Target(ElementType.METHOD) // 这是一个对方法的注解,还可以是包、类、变量等很多东西
 - @Retention(RetentionPolicy.RUNTIME) // 保留时间,一般注解就是为了框架开发时代替配置文件使用,JVM运行时用反射取参数处理,所以一般都为RUNTIME类型
 - @Documented // 用于描述其它类型的annotation应该被作为被标注的程序成员的公共API,因此可以被例如javadoc此类的工具文档化
 - public @interface OneAnnotation {
 -         // 定义注解的参数,类型可以为基本类型以及String、Class、enum、数组等,default为默认值
 -         String parameter1() default "";
 -         int parameter2() default -1;
 - }
 
  复制代码   
 2.使用注解的类 
  
- /**
 -  * 一个用到了自定义的注解的类
 -  */
 - public class OneClass {
 -         
 -         @OneAnnotation(parameter1="YES", parameter2=10000)
 -         public void oneMethod () {
 -         }
 - }
 
  复制代码   
3.提取注解参数 
  
  
- import java.lang.reflect.Method;
 - public class TestThis {
 -         public static void main(String[] args) throws Exception {
 -                 // 提取到被注解的方法Method,这里用到了反射的知识
 -                 Method method = Class.forName("OneClass").getDeclaredMethod("oneMethod");
 -                 // 从Method方法中通过方法getAnnotation获得我们设置的注解
 -                 OneAnnotation oneAnnotation = method.getAnnotation(OneAnnotation.class);
 -                 
 -                 // 得到注解的俩参数
 -                 System.out.println(oneAnnotation.parameter1());
 -                 System.out.println(oneAnnotation.parameter2());
 -         }
 - }
 
  复制代码   
测试结果: 
  
 YES 
 10000 
  
 |   
 
 
 
 |