• JavaWeb学习(4)注解案例:简单的测试框架


    一、步骤

    (1)定义一个注解 Check
    @Retention(RetentionPolicy.RUNTIME)
    @Target(ElementType.METHOD)
    public @interface Check {
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    (2)定义一个计算机类 Calculator

    注意有的方法加了Check注解,有的没有

    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));
        }
    
        //未加Check注解
        public void show(){
            System.out.println("bug给我退,退,退!");
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    可以明显看出有的方法是出错的,如add方法会有空指针异常,div方法分母不可为0

    (3)创建TestCheck类

    当TestCheck类中的主方法执行后,会自动自行被检测的所有方法(加了Check注解的方法),判断方法是否有异常,记录到文件中

    • 1.创建计算器对象
            //1.创建计算器对象
            Calculator c = new Calculator();
    
    • 1
    • 2
    • 2.获取字节码文件对象
            //2.获取字节码文件对象
            Class cls = c.getClass();
    
    • 1
    • 2
    • 3.获取所有方法
    // A code block
    var foo = 'bar';
    
    • 1
    • 2
    • 4.使用遍历判断方法上是否有Check注解
    • 5.有,执行
    • 6.捕获异常
    • 7.记录出现异常的次数
    • 8.记录到文件中
            //7.记录出现异常的次数
            int number = 0;
            //BufferedWriter用来将文本写入字符输出流,缓冲各个字符,从而提供单个字符、数组和字符串的高效写入。
            //FileWriter用来写入字符文件的便捷类
            BufferedWriter bw = new BufferedWriter(new FileWriter("bug.txt"));
    
            //4.使用遍历判断方法上是否有Check注解
            for (Method method : methods) {
                if (method.isAnnotationPresent(Check.class)){
                    //5.有,执行
                    try {
                        method.invoke(c);
                    } catch (Exception e) {
                        //6.捕获异常
                        //8.记录到文件中
                        number++;
    
                        bw.write(method.getName() + "方法出异常了!");
                        bw.newLine();
                        bw.write("异常的名称:" + e.getCause().getClass().getSimpleName());
                        bw.newLine();
                        bw.write("异常的原因:" + e.getCause().getMessage());
                        bw.newLine();
                        bw.write("=========================================");
                        bw.newLine();
    
                    }
                }
            }
            bw.write("本次测试一共出现" + number + "次异常");
            bw.newLine();
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 9.刷新该流的缓冲
            //9.刷新该流的缓冲
            bw.flush();
    
    • 1
    • 2
    • 10.关闭该流的缓冲
            //10.关闭该流的缓冲
            bw.close();
    
    • 1
    • 2

    二、具体实现

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    java实现图书管理系统
    docker创建service时动态获取服务名 模版占位符
    数据库系统原理与应用教程(045)—— MySQL 查询(七):聚合函数
    nacos代码示例
    【数据结构之B树的讲解】
    Kotlin高仿微信-第12篇-单聊-图片
    MySQL 性能压测工具-sysbench,从入门到自定义测试项
    JS:数组类型及常用的方法使用
    ZNS SSD是否真的前途一片光明?
    Windows上搭建一个网站(基本生产环境)
  • 原文地址:https://blog.csdn.net/xjl243636988/article/details/126739482