Java知识点总结(注解-自定义注解)
@(Java知识点总结)[Java, 注解]
使用@interface自定义注解时,自动继承了java.lang.annotation.Annotation接口
要点:
- @interface用来声明一个注解:public @interface 注解名 {定义体}
- 其中的每一个方法实际上是声明了一个配置参数, 方法的名称就是参数的名称
- 返回值类型就是参数的类型(返回值类型只能是基本类型,Class、String、Enumeration、Annotation)
- 可以通过default来声明参数的默认值
- 如果只有一个参数成员,一般参数名为value(), 在使用时可以忽略成员名和赋值符号=
- 注解类可以没有成员,没有成员的注解称为标识注解
注意:
- 注解元素必须要有值。我们定义注解元素时,经常使用空字符串、0作为默认值。
- 也经常使用负数(比如:-1)表示不存在的含义
示例:
import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target; @Target(value={ElementType.METHOD,ElementType.TYPE}) //既可以修饰方法,也可以修饰类@Retention(RetentionPolicy.RUNTIME) //运行时public @interface MyAnnotation { //使用@interface 关键字定义注解 String studentName(); //成员以无参无异常方式声明。方法的名称就是参数的名称 int age() default 18; // 可以使用default为成员指定一个默认值 String[] schools();}
public class Demo2 { @MyAnnotation(age=21,schools={"浙江大学","清华大学"},studentName="张三") public void test1() { }}