注解
注解(Annotation),也叫元数据。一种代码级别的说明。它是JDK1.5及以后版本引入的一个特性,与类、接口、枚举是在同一个层次。它可以声明在包、类、字段、方法、局部变量、方法参数等的前面,用来对这些元素进行说明,注释。
注解是计算机能够读懂的注释,注释是能够让程序员能够更便捷的读懂程序。
注解的作用
①编写文档:通过代码里标识的注解生成文档【生成文档doc文档】
②代码分析:通过代码里标识的注解对代码进行分析【使用反射】
③编译检查:通过代码里标识的注解让编译器能够实现基本的编译检查【Override】
注解案例
需求:编写一个简单的测试框架,要求若在方法上加上@Check注解后,需要测试该方法,如果某个方法抛出异常,则要求记录异常次数,并将异常信息写入txt文件中。
注解类
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Check {
}
待注解类
public class Calculator {
@Check
public void add(){
System.out.println("1+0"+(1+0));
}
@Check
public void sub(){
System.out.println("1-0"+(1-0));
}
@Check
public void mul(){
System.out.println("1*0"+(1*0));
}
@Check
public void div(){
System.out.println("1/0"+(1/0));
}
@Check
public void show(){
String str = null;
str.toString();
System.out.println("------代码永无bug------");
}
}
测试类
public class AnnoTest {
public static void main(String[] args) throws IOException {
Calculator calculator = new Calculator();
Class<? extends Calculator> cls = calculator.getClass();
Method[] declaredMethods = cls.getDeclaredMethods();
int num=0;
//BufferedReader br = new BufferedReader(new FileReader("bug.txt"));
BufferedWriter bw = new BufferedWriter(new FileWriter("bug.txt"));
for (Method declaredMethod : declaredMethods) {
declaredMethod.setAccessible(true);
if(declaredMethod.isAnnotationPresent(Check.class)){
try {
Object invoke = declaredMethod.invoke(calculator);
} catch (Exception e) {
num++;
bw.write(declaredMethod.getModifiers()+"方法出现了异常");
bw.newLine();
bw.write("异常名称:"+e.getCause().getClass().getSimpleName());
bw.newLine();
bw.write("异常原因"+e.getCause().getMessage());
bw.newLine();
bw.newLine();
System.out.println("-----------------------------");
}
}
}
bw.write("本次一种出现"+num+"次异常");
bw.newLine();
bw.flush();
bw.close();
}
}
测试结果
在java程序中注解应用是非常频繁的,在开发的过程中会看到大量的注解,本文先对注解有个全局的理解,如有必要,在后续的博文中将做详细的复习。