美文网首页
java基础之-自定义注解一

java基础之-自定义注解一

作者: 司马小小明 | 来源:发表于2018-06-23 19:12 被阅读0次

    (分类信息来自百度搜索)

    • 运行机制分类:
      • 源注解 代码中注解编译后class中没有
      • 编译时注解 再class中存在的
      • 运行时注解 运行时起作用的注解
    • 按来源分
      • JDK自带注解
      • 三方注解 最常见
      • 自定义注解
    • 元注解
      • 注解的注解

    今天来看看Java的自定义注解,看Java自定义注解前先看看jdk中的三个注解:@Override @Deprecated @SuppressWarnings
    @Override:表示当前类覆盖了父类的方法。@Deprecated:当前方法过时不再推荐使用 @SuppressWarnings:忽略警告。
    回归正题看看自定义注解:
    java通过@interface 实现注解.来看看下面的自定义注解。

    package com.annotation.annotation;
    import java.lang.annotation.ElementType;
    import java.lang.annotation.Retention;
    import java.lang.annotation.RetentionPolicy;
    import java.lang.annotation.Target;
    
    /**
     * @Target是这个注解的作用范围 ElementType.METHOD这个是方法级别的
     * 此外还有:CONSTRUCTOR(构造方法声明),FIELD(字段声明),LOCAL VARIABLE(局部变量声明),
     * METHOD(方法声明),PACKAGE(包声明),PARAMETER(参数声明),TYPE(类接口)
     */
    @Target(ElementType.METHOD)
    /**
     * @Retention是它的生命周期
     * 取值:SOURCE(只在源码显示,编译时丢弃),CLASS(编译时记录到class中,运行时忽略),
     * RUNTIME(运行时存在,可以通过反射读取)
     */
    @Retention(RetentionPolicy.RUNTIME)
    public @interface ShowMessage {
        /**
         * value是注解的成员变量(当只有一个成员变量时必须用value) 可以使用 default指定默认值。
         * 成员变量的类型限定必须是:基本的数据类型以及String,Class,Annotation,Enumeration
         * @return
         */
        String value() default "";
    }
    

    这样就定义完一个注解了。可是定义完了怎么用呢?
    下来提供两种解析自定义的注解的方式:1.java 反射解析自定义注解。2.使用Spring AOP 的Aspectj 解析自定义注解。
    话不多说直接上代码说明都在代码注释里

    1. java 反射解析自定义注解
    package com.annotation.impl;
    
    import com.annotation.annotation.ShowMessage;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    public class AnnotationUtile {
        private static Logger logger= LoggerFactory.getLogger(AnnotationUtile.class);
        //使用上面自定义的注解
        @ShowMessage("this is test")
        private void test(){
            logger.debug("测试信息");
        }
    }
    

    我这里使用JUNIT测试解析定义注解

    package com.annotation.impl;
    
    import com.annotation.annotation.ShowMessage;
    import org.junit.Test;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import java.lang.reflect.Method;
    
    public class TestMain {
        private static Logger logger= LoggerFactory.getLogger(TestMain.class);
    
        @Test
        public void  annotation(){
            try {
                //反射获取使用注解的类
                Class c = Class.forName("com.annotation.impl.AnnotationUtile");
                /**
                 * 这里我定义的是方法级注解,这里取对应的方法
                 */
                Method[] methods=c.getDeclaredMethods();
                for (Method method:methods){
                    /**
                     * isAnnotationPresent() 判断是否使用注解
                     * 判断AnnotationUtile是否有ShowMessage注解
                     */
                    Boolean ble = method.isAnnotationPresent(com.annotation.annotation.ShowMessage.class);
                    if (ble){
                        //获取注解的实例
                        ShowMessage showMessage = method.getAnnotation(ShowMessage.class);
                        //获取注解成员变量并打印
                        logger.debug(showMessage.value());
    
                    }
                }
    
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
    }
    

    运行结果如下:

    Connected to the target VM, address: '127.0.0.1:60534', transport: 'socket'
    19:02:21.837 [main] DEBUG com.annotation.impl.TestMain - this is test
    Disconnected from the target VM, address: '127.0.0.1:60534', transport: 'socket'
    
    Process finished with exit code 0
    

    一会看世界杯了 剩下的稍后再补充。计划注解再写两篇 一篇是Spring AOP 的Aspectj 解析自定义注解。另一篇是个综合应用(一个可扩展的校验注解:实现再特定业务下 校验功能)

    相关文章

      网友评论

          本文标题:java基础之-自定义注解一

          本文链接:https://www.haomeiwen.com/subject/dpblyftx.html