一.计算器类
步骤:
1.加法
2.减法
3.乘法
4.除法
package FanShe.annotation;
//定义的计算器类
public class Calculator {
@check
//加法
public void add(){
String str=null;
str.toString();
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));
}
public void show(){
System.out.println("永无bug");
}
}
二. 注解
package FanShe.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface check {
}
三. 测试
步骤
1.创建计算器对象
2.获取字节码文件
3.获取所有方法
4.判断方法是否有check注解
5.捕获异常
package FanShe.annotation;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
/**
*简单的测试框架
* 当主方法执行后,会自动监测的所有方法(加了check注解的方法),判断方法是否异常,记录到文件中
*/
public class CalculatorTest {
public static void main(String[] args) throws ClassNotFoundException, IOException {
//1.创建计算器对象
Calculator c=new Calculator();
//2.获取字节码文件
Class cls = c.getClass();
//3.获取所有方法
Method[] methods = cls.getMethods();
//出现异常的次数
int number=0;
BufferedWriter buff=new BufferedWriter(new FileWriter("bug.txt"));
//4.判断方法是否有check注解
for (Method method : methods) {
//5.有,执行
if(method.isAnnotationPresent(check.class)){
try {
method.invoke(c);
} catch (Exception e) {
// 6.捕获异常
//记录到文件中
number++;
//获取异常的方法
buff.write(method.getName()+"方法出异常了");
buff.newLine();
//获取异常的名称
buff.write("异常的名称"+e.getCause().getClass().getSimpleName());
buff.newLine();
//获取异常的原因
buff.write("异常的原因"+e.getCause().getMessage());
buff.newLine();
buff.write("-------------------");
buff.newLine();
}
}
}
buff.write("本次一共出现"+number+"次异常");
buff.flush();
buff.close();
}
}
四. 运行结果
1*0=0
1-0=1
五. 异常
add方法出异常了
异常的名称NullPointerException
异常的原因null
-------------------
div方法出异常了
异常的名称ArithmeticException
异常的原因/ by zero
-------------------
本次一共出现2次异常
作者:Aimee.洁
本文版权归作者和CSDN共有,欢迎转载,未经作者同意必须保留此版声明,否则保留追究法律责任的权利。
@喜欢的点赞关注,评论区留下宝贵的意见呐❥❥~