一、 Annotation 工作方式
功能: 允许开发者定义、使用自己的annotation类型。此功能由一个定义annotation类型。此功能由一个定义annotation 类型的语法和一个描述annotation 声明的语法,读取annotation的API,一个使用annotation的API,一个使用annotation修饰的class文件,一个annotation处理工具(apt)组成。
系统自带注解:
Override 注解: 表示子类需要重写(override)父类对应方法 。
Deprecated注解: 表示方法是不建议被使用的。
SuppressWarnings注解: 表示抑制警告。
package com.bob.annotation;
public class OverrideTest extends Object {
@Override
public String toString(){
return "This is OverrideTest.";
}
public static void main(String[] args) {
OverrideTest test = new OverrideTest();
System.out.println(test);
}
}
package com.bob.annotation;
import java.util.Date;
import java.util.Map;
import java.util.TreeMap;
public class SuppressWarningTest {
@SuppressWarnings({"unchecked", "deprecation"})
public static void main(String[] args) {
Map map = new TreeMap();
map.put("hello", new Date()); //压制警告
System.out.println(map.get("hello"));
Date date = new Date();
System.out.println(date.toLocaleString()); //压制不建议被使用的方法
}
}
二、 如何自定义注解
· 自定义注解:当注解中的属性名为 value 时,在对其赋值时可以不指定属性的名称而直接写上属性即可;除了 value 以外的其他值都需要使用 name=value 这种赋值方式,即明确指定给谁赋值。
· 当我们使用@interface 关键字定义一个注解时,该注解隐含地继承了 java.lang.annotation.Annotation,那么我们所定义的接口依然还是接口而不是注解;Annocation 本身是接口而不是注解。可以与Enum 类比。
package com.bob.annotation;
public @interface AnnotationTest {
String value1() default "hello"; //声明一个value1成员变量默认值hello
EnumTest value2();
}
enum EnumTest{
Hello, World, Welcome;
}
package com.bob.annotation;
@AnnotationTest(value2 = EnumTest.Welcome)
public class AnnotationUsage {
@AnnotationTest(value1 = "world", value2 = EnumTest.Hello)
public void method(){
System.out.println("usage of annocation");
}
public static void main(String[] args) {
AnnotationUsage usage = new AnnotationUsage();
usage.method();
}
}