简介:小编在刚开始学习注解的时候,真的是一个头两个大,真的搞不懂。现在思路清晰了之后决定通过小案例来说说注解。(小案例通过模拟一个Junit框架)
需求:定义若干个方法,只要加了MyTest注解,就可以在启动时被触发执行
分析:
1.定义一个自定义注解MyTest,只能注解方法,存活范围是一直都在。
2.定义若干个方法,部分方法加上@MyTest注解修饰,部分方法不加。
3.模拟一个junit程序,可以触发加了@MyTest注解的方法执行。
首先创建一个自定义注解MyTest,在自定义注解中规定了自定注解的适用范围是只能作用在方法上,自定义注解的存活范围是一直存活。代码如下。
package com.itheima_annotation;
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)
public @interface MyTest {
}
然后是创建一个模拟Junit框架(创建一个Junit类)。在类中定义了四个方法,其中两个方法添加了自定义注解,其他的则否。之后在主函数中通过反射获取类的Class对象,进而获取Class对象中的这四个方法,根据是否添加自定义注解来确定是否执行该方法。此功能模拟单元测试(Junit)的方法。详细代码如下。
package com.itheima_annotation;
import org.junit.Test;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
/**
* 目标:模拟junit框架的设计
*/
public class AnnotationTest {
@MyTest
public void test01(){
System.out.println("----自定义测试注解方法1----");
}
// @MyTest
public void test02(){
System.out.println("----自定义测试注解方法2----");
}
@MyTest
public void test03(){
System.out.println("----自定义测试注解方法3----");
}
// @MyTest
public void test04(){
System.out.println("----自定义测试注解方法4----");
}
public static void main(String[] args) throws Exception {
AnnotationTest test = new AnnotationTest();
// 获取Class对象
Class annotationTestClass = AnnotationTest.class;
// 通过Class对象,获取所有的方法
Method[] methods = annotationTestClass.getDeclaredMethods();
// 遍历所有的方法,验证每一个方法中是否有MyTest注解。若有,那么触发该方法执行。
for (Method method : methods) {
if (method.isAnnotationPresent(MyTest.class)){
// 说明该方法上是有MyTest注解,那么执行该方法。
method.invoke(test);
}
}
}
}
在代码中可以看到方法test01()、test03()方法添加了自定义注解,这两个方法执行了。其他方法未执行。执行结果如图。