文章目录
声明:该文章是cv的,因为害怕博主删文,所以将他的内容搬到我的博客下,并将里面的重点内容抽取出来,其他多余解释删除。
原文链接,戳这里
Java注解说明
使用范围
jdk1.5以上
三种标准注解
@Override,表示当前的方法定义将覆盖超类中的方法。
@Deprecated,使用了注解为它的元素编译器将发出警告,因为注解@Deprecated是不赞成使用的代码,被弃用的代码。
@SuppressWarnings,关闭不当编译器警告信息。
元注解
java注解使用
注解的可用类型
注解的可用的类型包括以下几种:所有基本类型、String、Class、enum、Annotation、以上类型的数组形式。元素不能有不确定的值,即要么有默认值,要么在使用注解的时候提供元素的值。而且元素不能使用null作为默认值。注解在只有一个元素且该元素的名称是value的情况下,在使用注解的时候可以省略“value=”,直接写需要的值即可。
示例demo
注解定义
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface UseCase {
public String id();
public String description() default "no description";
}
使用注解
public class PasswordUtils {
@UseCase(id = "47" , description = "Passwords must contain at least one numeric")
public boolean validatePassword(String password) {
return (password.matches("\\w*\\d\\w*"));
}
@UseCase(id = "48")
public String encryptPassword(String password) {
return new StringBuilder(password).reverse().toString();
}
}
注解处理器
从原理上讲,注解处理器就是通过反射机制获取被检查方法上的注解信息,然后根据注解元素的值进行特定的处理。
public static void main(String[] args) {
List<Integer> useCases = new ArrayList<Integer>();
Collections.addAll(useCases, 47, 48, 49, 50);
trackUseCases(useCases, PasswordUtils.class);
}
public static void trackUseCases(List<Integer> useCases, Class<?> cl) {
for (Method m : cl.getDeclaredMethods()) {
UseCase uc = m.getAnnotation(UseCase.class);
if (uc != null) {
System.out.println("Found Use Case:" + uc.id() + " "
+ uc.description());
useCases.remove(new Integer(uc.id()));
}
}
for (int i : useCases) {
System.out.println("Warning: Missing use case-" + i);
}
}
控制台输出
Found Use Case:47 Passwords must contain at least one numeric
Found Use Case:48 no description
Warning: Missing use case-49
Warning: Missing use case-50
Process finished with exit code 0
示例代码:github
思考与总结
1.根据以上注解的使用介绍,更加清楚了Spring内部的注解工作原理,无非就是通过反射获取注解,能取到相应注解的才做特殊处理,取不到,就不作处理,虽然总结的很low,但确实就是这样的。
2.那么我们平时都是扫描某某包下的类中的方法是否含有某某注解,这些如何做到?
可以参考代码:戳这里