如何阅读JDK和Spring中关于注解代码的浅析

4 篇文章 0 订阅

 

1.JDK中的@Resource注解

@Target({TYPE, FIELD, METHOD})
@Retention(RUNTIME)
public @interface Resource {
  
    String name() default "";

    String lookup() default "";

    Class<?> type() default java.lang.Object.class;

    enum AuthenticationType {
            CONTAINER,
            APPLICATION
    }

    AuthenticationType authenticationType() default AuthenticationType.CONTAINER;

    boolean shareable() default true;

    String mappedName() default "";

    String description() default "";
}

@Target({TYPE, FIELD, METHOD}) : 引入该注解,表示该注解可用的范围,上述@Resource注解可用于类,字段,方法上。

@Retention(RUNTIME) : 引入该注解,表示该注解可保留的范围,RUNTIME表示在jvm运行时也保留。

String name() default "":表示注解中可选的name字段,default设置默认值。

后面定义了一个枚举类型来表示@Resoure的两种身份认证类型。

2.Spring中的@RequestMapping注解

@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Mapping
public @interface RequestMapping {
    String name() default "";

    @AliasFor("path")
    String[] value() default {};

    @AliasFor("value")
    String[] path() default {};

    RequestMethod[] method() default {};

    String[] params() default {};

    String[] headers() default {};

    String[] consumes() default {};

    String[] produces() default {};
}

@Target,@Retention同上不再详细说了。

@Documented,引入这个注解表明这个注释是由 javadoc记录的,在默认情况下也有类似的记录工具。 如果一个类型声明被注释了文档化,它的注释成为公共API的一部分。

@Mapping,引入该注解。

RequestMethod[] method() default {}中定义了方法得请求方式GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS, TRACE;

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JDK ,内置了很多注解,其有些注解定义了参数,可以通过这些参数来定制注解的行为。下面是使用 JDK 内置注解参数的一些规则: 1. 定义注解参数时需要使用 @interface 关键字,并且参数类型只能是基本数据类型、String、Class、枚举类型、注解类型或这些类型的数组。 2. 参数定义时需要指定参数名和默认值。例如: ```java public @interface MyAnnotation { int value() default 0; String name() default ""; } ``` 上述代码定义了一个注解类型 MyAnnotation,其包含了两个参数:value 和 name。value 参数类型为 int,且默认值为 0;name 参数类型为 String,且默认值为空字符串。 3. 在使用注解时,可以省略参数名,直接指定参数值。例如: ```java @MyAnnotation(10, "Hello") public void myMethod() { // ... } ``` 上述代码使用了 MyAnnotation 注解,并为 value 参数指定了值 10,为 name 参数指定了值 "Hello"。 4. 如果只需要为某些参数指定值,而其他参数使用默认值,可以使用以下形式: ```java @MyAnnotation(value = 10) public void myMethod() { // ... } ``` 上述代码只为 value 参数指定了值 10,name 参数依然使用默认值。 5. 如果参数类型是枚举类型,可以使用以下形式指定参数值: ```java public enum MyEnum { VALUE1, VALUE2, VALUE3; } @MyAnnotation(MyEnum.VALUE1) public void myMethod() { // ... } ``` 上述代码使用了枚举类型 MyEnum,并为 MyAnnotation 注解的参数指定了枚举常量 MyEnum.VALUE1。 6. 如果参数类型是注解类型,可以使用以下形式指定参数值: ```java public @interface OtherAnnotation { int value(); } @MyAnnotation(@OtherAnnotation(10)) public void myMethod() { // ... } ``` 上述代码定义了一个注解类型 OtherAnnotation,并为 value 参数指定了值 10。然后在使用 MyAnnotation 注解时,将 OtherAnnotation 作为参数值传入。 以上就是使用 JDK 内置注解参数的一些规则。需要注意的是,注解参数只能用于限制编译时期的行为,不能影响运行时期的行为。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值