2023年4月26日14:36:47
刚开始学习javaweb,学的迷迷糊糊,始终不明白注解的作用还有框架到底是个啥,在自己敲完这Check小测试方法之后懂了许多
下面这个就是Check测试类,在使用时在所检查的代码上面写一个@Check 就能用了(和之前用过的@Test 好像),运行之后会创建一个bug.txt文本,来体现有什么异常,有几个异常等信息
package day01;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
//@author 靳嘉豪
//creates 2023-04-25-22:04
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Check {
}
package day01;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.lang.reflect.Method;
//@author 靳嘉豪
//creates 2023-04-25-21:51
public class TestCheck {
public static void main(String[] args) throws IOException {
// 1.创建计算机对象
Calculator c = new Calculator();
// 2.获取字节码文件对象
Class cls = c.getClass();
// 3.获取所有方法
Method[] methods = cls.getMethods();
int number = 0;
BufferedWriter bw = new BufferedWriter(new FileWriter("bug.txt"));
for (Method method : methods) {
// 4.判断方法上是否有Check注解
if (method.isAnnotationPresent(Check.class)) {
// 5.有的话执行
try {
method.invoke(c);
} catch (Exception e) {
// 6.捕获异常
// 记录到文件中
number++;
bw.write(method.getName() + "出现异常了");
bw.newLine();
bw.write("异常的名称" + e.getCause().getClass().getCanonicalName());
bw.newLine();
bw.write("异常的原因"+e.getCause().getMessage());
bw.newLine();
bw.write("---------");
}
}
}
bw.write("本次测试一共出现"+number+"次异常");
bw.flush();
bw.close();
}
}
以下是被检测的代码
package day01;
//@author 靳嘉豪
//creates 2023-04-25-21:53
public class Calculator {
// 加法
@Check
public void add() {
System.out.println("1 + 0=" + (1 + 0));
}
@Check
// 减法
public void sub() {
System.out.println("1 - 0=" + (1 - 0));
}
@Check
// 乘法
public void mul() {
System.out.println("1 * 0=" + (1 * 0));
}
@Check
// 除法
public void div() {
System.out.println("1 / 0=" + (1 / 0));
}
}
在TestCheck类中运行过后就会创建出一个bug.txt文本,如下图所示(他检测出来了div这个方法里面出现分母为零的情况)
其实如果嫌麻烦的话可以吧异常名称和异常原因写到一起(突然明白API的重要性)
bw.write("异常的名称/异常的原因" + e.getCause());
输出这个