注解小结
注解是个神秘的东西,下面让我带你初识注解
1.java中 常用的注解-------文档注解
@author 标明作者
@since 创作时间
@version 表名版本
2.java中 编译时期的注解-------编译检查
@Override 重写标志
@Deprecated 标志方法过期
@SuppressWarnings(“all”) 去除所有警告
3.自定义注解
3.1. 编写格式
public @interface 注解名{}
3.2.参数支持格式
String/enum/基本数据类型/Class类/Annotation类型/以上所有类型类型的数组。
3.3.参数修饰限定符:public/default.如果里面只有一个参数成员,最好把参数设为value,这样就可以("")省略属性名。
4.元注解:(作用:有时当我我们自己写注解时,不可使用时,要加元注解)
4.1.@Documented:可用于javadoc 文当的生成,只是一个标记注解,没有成员。
4.2.@Retention(XXX)策略:使用RetentionPolicy.XXX
如:SOURCE/CLASS/RUNTIME/
4.3.@Target(XXX)可以使用在哪:使用ElementType.XXX点出来,METHOD(方法上可以使用)/TYPE/PACKAGE/CONSTRUCTOR/PARAMETER
4.4 @Inherited 继承:一个类的子类依旧可以传递使用。
5示例
package com.srzx.demo03;
import java.lang.annotation.*;
import static java.lang.annotation.ElementType.*;
//元注解
@Documented //文档注释可以用
/**
* 保留时机:RetentionPolicy下
*/
@Retention(RetentionPolicy.RUNTIME) //保留策略(该注解要保留到什么时候 编译/运行/源码) 运行是调用
/**
* 类型都在ElementType下
*/
@Target(value={ElementType.CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE}) //可以用到的地方
/**
* 支持的返回值类型 SSS Z feedback 反馈
* String enum Class Annotation 基本数据类型 五种类型
*/
public @interface MyAnnotation {
//当只有一个成员时,可以将名称起为value ,而且可以省掉写value;
//属性只能用public/default修饰
int eat();
boolean isOK() default false;
}