注解(是一种特殊标记,使用这种标记可以逆向控制程序流程)

1.为何要有注解

我们希望在代码中的某些地方,做一些标识,然后在稍后的某个时刻(比如在程序执行过程中),将这些标识取出来,对使用注解的那部分进行一些分类和处理,注解基本上可以用来修饰万物

注解可以简单干净的实现上述需求,将标识与源代码文件结合,并且提供了编译期检查,多用于文件配置、事务管理、切面、测试等场景。注解与反射是绝配

单独定义注解并没有实际意义,获取注解之后的注解处理流程才是需要关注的。

2.注解的基础知识

2.1 三大内置注解
@Override 重写注解
@Deprecated 过时注解
@SuppressWarnings 抑制编译器告警注解
2.2 四大元注解(专门负责新注解的创建)
@Retention保留范围注解(原文件、编译、运行)
@Target 范围注解(包、类、方法、构造器、参数、循环等)
@Inherited 可继承注解
@Documented 文件型注解
2.3 JDK1.8新增的特殊注解
@Repeatable 可重复注解
@Target 范围注解的扩充 类型参数声明注解、可以使用在任何位置的注解

3.自定义注解

3.1 自定义注解

代码如下

@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})//1.使用元注解,表明此注解可以在如下的位置使用
@Retention(RetentionPolicy.RUNTIME)//此元注解表明,此注解会在运行期保存,只有这一种RUNTIME我们可以通过反射获取
public @interface MyAnnotation {

    //2.编写注解的内部成员,可以没有也可以有多个
    String value() default "hello";//给注解的成员赋默认值,所有成员必须有值,如果此处不写默认值,使用的时候要显式的赋值

}

3.2 使用自定义的注解

代码如下

/**
 * ===========================================================
 * @function 这个类用来测试@MyAnnotation的使用
 * ===========================================================
 */
public class MyAnnotationTest {

    public void test1(String param){
        System.out.println(param+" test1");
    }

    @MyAnnotation
    public void test2(String param){
        System.out.println(param+" test2");
    }

    public static void main(String[] args) {
        MyAnnotationTest test = new MyAnnotationTest();
        //反射获取所有的方法
        Method[] methods = test.getClass().getDeclaredMethods();
        //遍历方法,找到带有@MyAnnotation的
        for (Method method : methods) {
            MyAnnotation annotation = method.getDeclaredAnnotation(MyAnnotation.class);
            if(annotation!=null){
                try {
                    //使用反射执行该方法
                    method.invoke(test,"hello");
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                } catch (InvocationTargetException e) {
                    e.printStackTrace();
                }
            }
        }
    }//hello test2

}

4.补充知识

1.Annotation的成员变量,是以无参数方法的形式来声明,如String value() default “hello”
2.没有成员变量的注解,称为标记;包含的被称为元数据
3.注解成员变量,只能是基本数据类型、String、Class、enum、Annotion,及以上所有类型的数组,没有基本类型包装类
4.自定义注解时可以参照三大内置注解进行编写
5.基于注解的单元测试:

1.我们可以直接在本类中使用@Test编写测试方法,这是一种很高效的方法,尤其对于获取private的属性等而言
2.我们也可以使用继承的方式,让测试类继承本类,然后编写测试方法
3.单元测试的固定格式是方法不带参数且返回值类型为void
4.java中的断言函数,可以代替你走分支
5.测试代码大多数时候我们并不想让其上线,或者暴露给客户
### 回答1: 是的,Java 注解可以理解为一种特殊的注释。注解Java 编程语言中的一种元素,它可以在编译时或运行时被读取。注解可以用来为 Java 程序中的元素(如类、方法、变量等)添加元数据,这些元数据可以被 Java 的编译器或运行时环境使用注解的语法与注释的语法相似,但是它们的功能更加强大。 注解使用方式也很简单,只需要在需要添加注解Java 元素前面加上@符号,然后指定注解的名称即可。例如,下面的代码使用@Override注解来标注一个方法: ``` public class MyClass { @Override public String toString() { return "MyClass"; } } ``` Java 程序也可以自定义注解使用@interface关键字来声明一个注解类型,然后在注解类型中定义注解的属性。例如,下面的代码定义了一个名为MyAnnotation的注解类型,其中有一个名为value的属性: ``` @interface MyAnnotation { String value(); } ``` 注解使用方式与普通的类似,只需要在需要添加注解的元素前加上@符号,然后指定注解的名称和属性值即可。例如,下面的代码使用MyAn ### 回答2: Java注解可以理解为一种特殊的注释,但它不仅仅是传统注释的扩展,还具有一定的功能和作用。 首先,注解一种在源代码中存在的特殊标记,不会参与实际的编译和运行过程,因此不会影响程序的执行结果。相较于传统注释,注解能够在程序中提供额外的信息,并且能够被编译器或者其他工具所读取和利用。 其次,注解可以用于为程序中的代码、类、方法、字段等元素附加元数据(metadata)。它们可以用来描述程序的行为、使用说明、配置参数等信息。通过使用注解,开发者可以在代码中加入相应的标记,使代码的含义更加清晰明确。 另外,注解还可以用于完成一些特定的逻辑操作。例如,可以根据注解来生成相应的代码、指定运行时的行为,或者进行代码检查等。一些常见的注解,如@Override、@SuppressWarnings等,已经在Java的标准库中提供,并被广泛应用于代码的编写和维护过程中。 总的来说,Java注解一种特殊的注释,但它不仅仅是用来说明、备注代码的,还具有一定的功能和作用。通过合理地使用注解,可以提高代码的可读性、可维护性和可扩展性。 ### 回答3: Java注解可以理解为一种特殊的注释,但它与普通的注释在功能和作用上有很大的不同。 首先,Java注解是向编译器或其他工具提供额外信息的方法。它可以应用于类、方法、变量等程序元素上,用于提供额外的元数据信息。而普通的注释只是对代码进行说明,对编译器或其他工具没有实际的影响。 其次,Java注解可以通过反射机制在运行时获取并处理。这使得我们可以在运行时通过注解来实现一些特定的逻辑。例如,可以通过注解来实现权限控制、数据验证等功能。而普通的注释在运行时是无法获取和处理的。 此外,Java注解还可以通过工具生成文档、进行代码分析、实现自动化的代码生成等。它允许我们对代码进行更灵活的控制和处理。 综上所述,虽然Java注解可以理解为一种特殊的注释,但它远不止于普通注释的功能。它是一种用于提供额外元数据信息、可以在运行时处理的特殊机制。通过注解,我们可以实现更加灵活和强大的代码控制和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值