栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java-注解、元注解、注解解析、模拟Junit框架总结

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java-注解、元注解、注解解析、模拟Junit框架总结

个人简介

  • 大家好,我是韩慧腾。一名正在努力学JAVA的大一小白,本文章为初学的笔记,希望各位多多指教。
  • 欢迎点赞+收藏+留言
  • 喜欢得不一定想得到,想得到的一定很喜欢李

一、注解

概述:Java注解又称Java标注;Java语言中的类、构造器、方法、成员变量、参数都可以被注解进行标注。

作用:对Java中类、方法、成员变量做标记,然后进行特殊处理。

自定义注解格式:

特殊属性:

  • value属性,如果只有一个value属性的情况下,使用value属性的时候可以省略value名称不写
  • 如果有多个属性,且多个属性没有默认值,那么value名称是不能省略的

理解:就是看有几个没有默认值的属性,若只有一个,属性名称可以省略的;否则,不能省略。

package com.itheima_01.Annotation;


@aa(age=18,sex="nv")
public class AnnotationDemo_0 {
    @aa(age=18,sex="nv")//标注成员变量
    String a;
    public static void main(String[] args) {
        @aa(age=18,sex="nv")//标注局部变量
        int b;
    }
}
@interface aa{
    String name() default "hhhhh";//设置默认值
    int age();
    String sex();
}

二、元注解

元注解就是放在注解上的注解。

常见的元注解:

  1. @Target:约束自定义注解只能在某些地方使用
package com.itheima_01.Annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Target;


public class AnnotationDemo_01 {
    @bb//此时就会报错,因为元注解规定了只能注解构造器和方法
    String name;
    String sex;
    int age;
    @bb
    public AnnotationDemo_01(){

    }
    @bb
    public void eat(){
        System.out.println("狂吃不胖");
    }

}
@Target({ElementType.METHOD,ElementType.CONSTRUCTOR})//元注解;规定该注解只能在构造器和方法使用
@interface bb{

}

2. @Retention:申明注解的声命周期

 

package com.itheima_01.Annotation;

import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;


public class AnnotationDemo_01 {
    @bb//此时就会报错,因为元注解规定了只能注解构造器和方法
    String name;
    String sex;
    int age;
    @bb
    public AnnotationDemo_01(){

    }
    @bb
    public void eat(){
        System.out.println("狂吃不胖");
    }

}
@Retention(RetentionPolicy.RUNTIME)//元注解,声明该注解的周期 注解bb作用在源码阶段、文件阶段、运行阶段
@interface bb{

}

三、注解解析

概述:注解的操作中经常需要进行解析,注解的解析就是判断是否存在注解,存在注解就解析出内容。Annotation是注解的顶级接口,注解都是Annotation类型的对象;AnnotationElement接口定义了与注解解析相关的解析方法

注意:所有的类成分Class,Method,Field,Constructor都实现了AnnotationElement接口,都具有注解解析的能力。

 

package com.itheima_01.Annotation;

import java.lang.annotation.*;
import java.lang.reflect.Method;
import java.util.Arrays;


public class AnnotationDemo_02 {
    public static void main(String[] args) throws NoSuchMethodException {
        //先创建类对象
        Class bookStoreClass = BookStore.class;
        Method see = bookStoreClass.getDeclaredMethod("see");
        //判断该类是否存在这个注解
        if(bookStoreClass.isAnnotationPresent(Book.class)){
            //获取该注解
            Book declaredAnnotation = (Book) bookStoreClass.getDeclaredAnnotation(Book.class);
            System.out.println(declaredAnnotation.name());
            System.out.println(declaredAnnotation.price());
            System.out.println(Arrays.toString(declaredAnnotation.author()));
        }
        if(see.isAnnotationPresent(Book.class)){
            Book declaredAnnotation = see.getDeclaredAnnotation(Book.class);
            System.out.println(declaredAnnotation.name());
            System.out.println(declaredAnnotation.price());
            System.out.println(Arrays.toString(declaredAnnotation.author()));
        }
    }
}
@Target({ElementType.TYPE,ElementType.METHOD})//元注解,该注解只能注解类和方法
@Retention(RetentionPolicy.RUNTIME)//元注解 声明该注解的存在周期
@interface Book{
    String name();
    double price() default 100;
    String[] author();
}
@Book(name="《Java编程思想》",price = 99.1,author = {"a","b","c"})
class BookStore{
    @Book(name="《Java从入门到入土》",author = {"aa,bb,cc"})
    public void see(){

    }
}

四、注解的应用

案例:模拟Junit框架

需求:定义若干个方法,只要加了MyTest注解,就可以在启动时被触发执行

package com.itheima_01.Annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Method;


public class AnnotationDemo_03 {
    @MyTest
    public void test1(){
        System.out.println("test1执行");
    }
    @MyTest
    public void test2(){
        System.out.println("test2执行了");
    }
    @MyTest
    public void test3(){
        System.out.println("test3执行了");
    }
    //实现调用有注解的
    public static void main(String[] args) throws Exception {
        AnnotationDemo_03 annotationDemo_03 = new AnnotationDemo_03();
        Class annotationDemo_03Class = AnnotationDemo_03.class;
        Method[] declaredMethods = annotationDemo_03Class.getDeclaredMethods();
        for (Method declaredMethod : declaredMethods) {
            if(declaredMethod.isAnnotationPresent(MyTest.class)){
                declaredMethod.invoke(annotationDemo_03);
            }
        }
    }
}
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@interface MyTest{

        }

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/855105.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号