Java自定义注解的使用

注解的定义

注解是一种能被添加到java源代码中的元数据,可以看做是是一种特殊标记,可以在包、类、参数和方法上使用,可以进行一些特殊的处理。
访问修饰符必须为public,不写默认为public。

元注解

JDK中有一些元注解来修饰注解,主要包括@Target,@Retention,@Document,@Inherited。
@Target:可以应用的java类型

Target说明
ElementType.TYPE应用于类、接口(包括注解类型)、枚举
ElementType.FIELD应用于属性(包括枚举中的常量)
ElementType.METHOD应用于方法
ElementType.PARAMETER应用于方法的形参
ElementType.CONSTRUCTOR应用于构造函数
ElementType.LOCAL_VARIABLE应用于局部变量
ElementType.ANNOTATION_TYPE应用于注解类型
ElementType.PACKAGE应用于包
ElementType.TYPE_PARAMETER1.8版本新增,应用于类型变量
ElementType.TYPE_USE1.8版本新增,应用于任何使用类型的语句中(例如声明语句、泛型和强制转换语句中的类型)

@Retention:表示注解的生命周期

Retention说明
RetentionPolicy.SOURCE编译时被丢弃,不包含在类文件中
RetentionPolicy.CLASSJVM加载时被丢弃,包含在类文件中,默认值
RetentionPolicy.RUNTIME由JVM 加载,包含在类文件中,在运行时可以被获取到

@Document:表示可以被Javadoc工具文档化
@Inherited:子类也会拥有这个注解

定义一个注解

定义在类上

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface TestType {

    String ClassName();
}

定义在字段上

@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface TestField {

    String fieldName();

    boolean isFlag() default false;
}

定义在方法上

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface TestMethod {

    String methodName();

}

在类中使用

@TestType(ClassName = "Person")
public class Person {

    @TestField(fieldName = "name")
    private String name;

    @TestField(fieldName = "age",isFlag = true)
    private int age;

    @TestMethod(methodName = "eat")
    public void eat() {
        System.out.println("吃饭");
    }
}

获取注解

使用反射去解析注解,获取注解里的参数

public class Test {
    public static void main(String[] args) {
        // 获取反射对象
        Class<Person> personClass = Person.class;
        // 获取类上的注解
        personClass.isAnnotationPresent(TestType.class);
        // 获取字段上的注解
        Field[] declaredFields = personClass.getDeclaredFields();
        // 获取方法的注解
        Method[] methods = personClass.getDeclaredMethods();
        if (methods != null) {
            for (Method m : methods) {
                // 判断方法上是否有注解
                if (m.isAnnotationPresent(TestMethod.class)) {
                    // 取到注解的值
                    String methodName = m.getAnnotation(TestMethod.class).methodName();
                    System.out.println(m.getName() + "方法使用了TestMethod注解," + "注解的methodName值为:" + methodName);
                }
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java自定义注解使用场景有很多,以下是其中几个常见的场景: 1. 代码级别的标记:自定义注解可以用来将特定的标记注解到代码中,以便在后续的处理中能够根据这些标记进行相应的逻辑处理。比如,可以自定义一个注解来标记某个方法需要进行性能监控,然后在运行时通过反射获取到被标记的方法,从而进行性能监控的统计。 2. 配置文件读取:自定义注解可以用来读取配置文件中的参数,从而简化配置文件的读取和解析过程。比如,可以自定义一个注解来读取配置文件中的数据库连接信息,然后通过反射获取到被标记的字段,并将配置文件中的参数设置到对应的字段上。 3. 代替XML配置文件:自定义注解可以用来代替繁琐的XML配置文件,从而简化配置的过程。比如,可以自定义一个注解来标记某个类需要在启动时进行初始化,然后在启动时扫描所有被标记的类,并进行相应的初始化操作。 4. AOP编程:自定义注解可以用来实现面向切面编程(AOP),将横切逻辑从业务逻辑中解耦出来。比如,可以自定义一个注解来标记某个方法需要进行事务处理,然后在运行时根据该注解进行事务的开启、提交或回滚。 总的来说,自定义注解使用场景较为广泛,可以根据具体的需求来合理地运用。它能够提高代码的可读性和维护性,同时也能够简化一些繁琐的操作,提高开发效率。但需要注意的是,自定义注解只是一种元数据的定义,需要通过反射等手段来读取和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值