AspectJ学习小笔记

文章背景

在慕课网学习Spring入门篇视频教程时,我遇到一个问题:一个接口名额外多加一个@。对此,写此文总结。

正文

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Mmethod {
    String value();
}

在接口Mmethod类中,我在interface前添加了@。初学者不太懂@的用途,@在这里是自定义注解类型。

首先要明白,注解有什么用处?

注解是一种能被添加到java代码中的元数据,类、方法、变量、参数和包都可以用注解来修饰。注解对于它所修饰的代码并没有直接的影响。
注解又许多用法,其中有:为编译器提供信息 - 注解能被编译器检测到错误或抑制警告。编译时和部署时的处理 - 软件工具能处理注解信息从而生成代码,XML文件等等。运行时的处理 - 有些注解在运行时能被检测到。
解释后,返归到代码中在编写Mmethod类时,我希望MoocBiz能继承Mmethod,同时并使用Mmethod中的方法。所以我利用@去注册此方法。

@Target(ElementType.METHOD)这段代码原本应该写为@Target(value = {ElementType.TYPE})。但是根据自定义注解语法——如果注解中的某个注解类型元素是一个数组类型,在使用时又出现只需要填入一个值的情况,那么在使用注解时可以直接写为:@注解名(类型名 = 类型值),它和标准写法:@注解名(类型名 = {类型值})等效!由于我只需要ElementType.METHOD,所以我就简略写成@Target(ElementType.METHOD)

@Service("MoocBiz")
public class MoocBiz {

    @Mmethod("MoocBiz save with Mmethod")
    public String save(String arg) {
        System.out.println("Biz save :" + arg);
//        throw new RuntimeException();
        return "Save success!";
    }
}

同理,@Mmethod(“MoocBiz save with Mmethod”)中原本也应是@Mmethod(name = “MoocBiz save with Mmethod”)

参考文章:https://blog.csdn.net/xsp_happyboy/article/details/80987484

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

烤鲅鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值