【Java学习笔记(二十)】之注解的作用与使用介绍

本文章由公号【开发小鸽】发布!欢迎关注!!!


老规矩–妹妹镇楼:

一. 注解

(一) 概述

        也叫元数据。一种代码级别的说明。它是JDK1.5及以后版本引入的一个特性,与类、接口、枚举是在同一个层次。它可以声明在包、类、字段、方法、局部变量、方法参数等的前面,用来对这些元素进行说明,注释。

(二) 使用方法

        @注解名称

(三) 注解的作用

1. 编写文档

        通过代码里标识的注解生成文档。

2. 代码分析

        通过代码里标识的注解对代码进行分析

3. 编译检查

        通过代码里标识的注解让编译器能够实现基本的编译检查(如@Override)


二.JDK内置注解

1. @Override

        检测该注解标注的方法是否是继承自父类的。

2. @Deprecated

        表示该注解标注的内容已经过时了,可以用但是不建议使用。

3. @SuppressWarnings

        抑制警告,抑制已经显示的警告。一般传递参数all

@SuppressWarnings(“all”)

三 自定义注解

(一) 格式

元注解
public @interface 注解名称{}

(二) 注解的本质

        注解本质上是一个接口,改接口默认继承Annotation接口

(三) 注解的属性

        注解中的属性即接口中的抽象方法,属性的返回值类型只能用以下的类型:

  1. 基本数据类型
  2. String
  3. 枚举
  4. 注解
  5. 以上类型的数组

        定义了属性后,在使用注解时需要给属性赋值。即给抽象方法的返回值赋值。

注意:
        如果使用default关键字给属性默认初始化值,则使用注解时可以不赋值属性。
        如果只有一个属性要赋值,该属性名称为value,则value可省略直接定义值。


四.元注解

(一)概述

        预定义的注解,用于描述注解的注解。

(二)举例

1. @Target

        用于描述注解能够作用的位置

TYPE:作用于类上
METHOD:作用于方法上
FIELD:作用于成员变量上

2.@Retention

        描述注解被保留的阶段,三个阶段:源代码夹断,Class类阶段,运行阶段。

@Retention(RetentionPolicy.SOURCE)
@Retention(RetentionPolicy.CLASS)
@Retention(RetentionPolicy.RUNTIME)

3. @Documented

        描述注解是否被抽取到api文档中显示。

4. @Inherited

        描述注解是否被子类继承


五.注解的使用

        注解通常用于取代配置文件,通过解析注解即可获取注解中定义的属性。

(一) 定义注解:

@Target({Element.Type.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface Pro{
	String className();
	String methodName();
}

(二) 定义类

@Pro(className = “xx.xx”, methodName = “xx”)
public static class ReTest{}

        我们要在ReTest类中利用注解取得相应的className和methodName,需要通过以下的步骤来获取。

1. 解析注解

        获取该类的字节码文件对象

Class<ReTest> ret = ReTest.class;

2. 获取注解定义位置的对象

        获取注解对象就是在内存中生成了该注解接口的子类实现对象。

Pro an = ret.getAnnotation(Pro.class)

3. 调用注解对象中定义的抽象方法,获取返回值
String className = an.className();
String methodName = an.methodName();

六.注解用于搭建简单的测试框架

(一)需求

        将注解加于方法之上,即可测试该方法是否会出现异常,并将异常记录在文件中。

(二)代码

        测试计算器类Calculator中的方法是有会出现异常,将@Check注解放置于方法上,有注解的方法被测试类TestCheck测试,测试结果放在bug.txt文本文件中。

每个文件的代码如下:

1. 计算器类Calculator
package 注解实现测试框架;

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 div(){
        System.out.println("1 / 0 = " + (1 / 0));
    }
}

2.自定义注解@Check

package 注解实现测试框架;

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 {

}

3.测试类

package 注解实现测试框架;

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

public class TestCheck {
    public static void main(String[] args) throws IOException {
        Calculator c = new Calculator();
        //获取该类的字节码文件对象
        Class<? extends Calculator> cls = c.getClass();
        //获取所有方法
        Method[] methods = cls.getMethods();

        int num = 0;
        BufferedWriter bw = new BufferedWriter(new FileWriter("bug.txt"));

        for(Method method : methods){
            //判断方法上是否有Check注解
            if(method.isAnnotationPresent(Check.class)){
                //有Check注解,执行
                try{
                    method.invoke(c);
                } catch (Exception e) {
                    //捕获异常,记录到文件中

                    num++;
                    bw.write(method.getName() + "方法出现异常");
                    bw.newLine();
                    bw.write("异常的名称:" + e.getCause());
                    bw.newLine();
                    bw.write("异常的原因:" + e.getMessage());
                    bw.newLine();
                    bw.write("----------------");
                    bw.newLine();
                }
            }
        }

        bw.write("本次测试一共出现" + num + "次异常");

        bw.flush();
        bw.close();

    }
}
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java SSM(Spring+SpringMVC+MyBatis)是一种基于Java语言的Web开发框架。学习这个框架的过程中,我深刻体会到它的强大和灵活性。 首先,Spring框架为开发者提供了一个强大的IOC(Inversion of Control)容器,它能够管理和注入对象,减少了代码之间的耦合性。通过配置文件或注解,我们可以轻松地定义和获取各种对象,提高了代码的可维护性和可扩展性。 其次,SpringMVC框架是一种MVC(Model-View-Controller)设计模式的实现,它用于处理Web请求和响应。通过配置一个请求映射表和处理器,我们可以将请求分发给相应的控制器进行处理,并将处理结果返回给客户端。SpringMVC还提供了一些便捷的注解和标签,用于简化页面的渲染和参数的绑定。 最后,MyBatis是一种优秀的持久化框架,它能够将数据库操作与Java对象之间的映射简化为简单的配置。通过编写SQL映射文件和定义POJO(Plain Old Java Object)类,我们可以方便地进行数据库的增删改查操作,而无需编写冗长的SQL语句。 在学习Java SSM框架的过程中,我深入理解了软件开发过程中的MVC思想,并学会了如何利用Spring、SpringMVC和MyBatis来实现一个完整的Web应用程序。通过不断的实践和调试,我逐渐培养了自己解决问题和调试代码的能力。 总结起来,学习Java SSM框架使我深入理解了软件开发的各个环节,并提升了我的编码能力和开发效率。我相信这些知识和经验将对我的职业发展和项目实施起到积极的促进作用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值