文章背景
在慕课网学习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