java aliasfor_@AliasFor注解

@AliasFor注解

@AliasFor是一个注解,用于为注解属性声明别名。

代码如下:它有两个属性value和attribute @AliasFor注解注释了

自身,并且value和attribute互为别名

456adba51c5fc17cb31e36c8a531a1fd.png

把多个元注解的属性组合在一起形成新的注解

如我们熟知的@SpringBootApplication :

c1633bad94000341171bdbebef7f7204.png

如上所示@SpringBootApplication并没有定义新的属性而是复用其他注解已有的注解属性并对其进行组合

形成新的注解从而到达到便捷的目的。这样的注解我们可以称之为复合注解。

所以在使用SpringBoot 时我们只需要@SpringBootApplication一个注解就能开启

自动配置,自动扫描的功能。

而不再需要使下面三个注解来达到同样的目的。

@Configuration

@ComponentSan

@EnnableAutoConfiguration

2.继承注解的功能

如@Controller,@Service,@Repository都继承了@Component的功能

他们的基本作用和@Component完全一样都是标明某个类是

Spring的Bean,需要Spring容器进行管理。不同之处在于对Spring bean进行了归类,从而能对不同类型的Bean进行不同的处理。

@Service代码如下

80efabec3d8aff3821d24c376b6088c8.png

在同个注解中为同一个功能定义两个名称不一样的属性,那么这两个属性彼此互为别名

如@RequestMapping注解中的value和path它们两互为别名。如下所示:

2292b707d20bc9af3e66327db6dcf00c.png

这么做的目的在于

1.更便捷

当我们只定义一个属性的时候往往可以省略属性名如:

@RequestMapping(“/user”)

2.顾名思义

当我门定义多个属性时为了能做到顾名思义

使之达到一目了然的效果我们需要选择一个更加贴合特定场景的名称。

@RequestMapping(path = “/user”,method = RequestMethod.GET)

当然你也可以这样:

@RequestMapping(value = “/user”,method = RequestMethod.GET)

只是这样子的定义value = “/user” 不能很准确地传达代码的意图。

根据@AliasFor的使用形式我们可以将它分为三类:

1.注解内部的显性别名

在单个注解中,可以把@AliasFor声明在一对属性上标明它们彼此之间互无别名如下所示: ContextConfiguration中的value和locations是彼此的显性别名

16c951171b5af0478fe431860c5765df.png

实现要求:

1.组成别名对的每个属性都必须用@AliasFor进行注释,并且AliasFor中的值

必须指向别名对中的另一个属性

2.别名化的属性必须声明相同的返回类型

3.别名化的属性必须声明默认值

4.别名化的属性默认值必须相同

2.用于元注解属性的显性别名

如果被@AliasFor注释的属性指向的是它所在注解之外的其他注解,

那么这个属性被解释成元注解属性的别名。(称之为显性的元注解属性重写)

我们可以通过重写继承一个或多个其他注解的功能从而

使得可以更细粒度精准地控制注解层级中属性的重写,

不像Java中继承必须继承父类的所有功能。

实际上,使用@AliasFor甚至可以为元注解的value属性声明别名.

如下所示:@MyTestConfig下的xmlFiles指向的是一个元注解@ContextConfiguration的属性locations

0d13bee0f6c1f1e33bf4dbd610f95ddd.png

实现要求:

1 如果一个属性是一个元注解属性的别名,那么这个属性必须用@AliasFor进行注释并且

该属性必须指向元注解属性。

2 别名化的属性必须声明相同的返回结果

3.@AliasFor的annotation属性必须引用元注解

4.被引用的元注解必须放置在声明了@AliasFor的注解类上

3 注解中的隐性别名

如果注解中的一个或多个属性声明为同一个元注解属性的属性重写(直接地或传递地重写)

那么这些注解会被当作彼此的隐性别名集来对待

结果是它们的行为类似于注解中的显性别名

如下所示:@MyTestConfig中,value,groovyScripts和xmlFiles

都是复写了@ContextConfiguration中locations属性的,因此这

三个属性是彼此的隐性别名。

701119ffec0f8ce015e11444f4504ff9.png

注解中的可传递隐性别名

如下所示:在GroovyOrXmlTestConfig中,groovy是对上面的MyTestConfig中的groovyScripts属性显示的复写,

而xml是对@ContextConfiguration中locations属性的显示的复写,

我们就可以称groovy和xml是彼此的可传递隐性别名,因为它们实际上只是复写ContextConfiguration中的locations属性。

f7ffa9c1095130df10bce295c8091562.png

实现要求:

1.属于隐性别名组中的每一个属性必须使用@AliasFor进行注释,并且attribute必须引用相同元注解中的同一个属性

2.别名化的属性必须声明相同的返回类型

3.别名化的属性必须定义默认值

4.别名化的属性必须声明相同的默认值

5.注解必须引用合适的元注解

6.被引用的元注解必须放置在声明了@AliasFor的注解上

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值