目录:
1,概念
2,关于注解~作用
3,java 注解格式
4,注解的分类
1)按照运行机制划分
2)按照来源划分
3)元注解
5,Java内置注解
@Override
@Deprecated
@SuppressWarnnings
6,自定义注解
✿ 语法
✿自定义注解在实际中小例子:
✿定义注解中的属性
1,概念: Annotation(注解)就是Java提供了一种元程序中的元素关联任何信息和着任何元数据(metadata)的途径和方法。Annotion(注解)是一个接口,程序可以通过反射来获取指定程序元素的Annotion对象,然后通过Annotion对象来获取注解里面的元数据。注解本质是一个接口,该接口默认继承 java.lang.annotation.Annotation 接口。注解中的属性是抽象方法。
2,关于注解:
✿注解本身不起作用,起作用的是注解解释器,注解需要和反射一起使用才能发挥大的威力。(通过反射获取注解信息)在Java技术里注解的典型应用是:可以通过反射技术去得到类里面的注解,以决定怎么去运行类。(ps:注解并不会自己生效(因为注解是接口)。必须通过某些程序或者是注解器或者是某些工具来获取并处理注解。例如,通过反射获取。)
① 生成文档。这是最常见的,也是java 最早提供的注解。常用的有@see @param @return 等;
② 跟踪代码依赖性,实现替代配置文件功能。比较常见的是spring 2.5 开始的基于注解配置。作用就是减少配置。现在的框架基本都使用了这种配置来减少配置文件的数量;
③ 标记检查,在编译时进行格式检查。如@Override放在方法前,如果你这个方法并不是覆盖了超类方法,则编译时就能检查出;
④编译时和部署时处理ーー软件工具可以处理注释信息以生成代码、 XML 文件等等。
3,java 注解格式:以@ 作为标志的格式为:@+自定义字符串
4,注解的分类
1)按照运行机制划分:
【源码注解→编译时注解→运行时注解】
源码注解:只在源码中存在,编译成.class文件就不存在了。
编译时注解:在源码和.class文件中都存在。像前面的@Override、@Deprecated、@SuppressWarnings,他们都属于编译时注解。
运行时注解:在运行阶段还起作用,甚至会影响运行逻辑的注解。像@Autowired自动注入的这样一种注解就属于运行时注解,它会在程序运行的时候把你的成员变量自动的注入进来。
2)按照来源划分:
【来自JDK的注解——来自第三方的注解——自定义注解】
3)元注解:
元注解是给注解进行注解,可以理解为注解的注解就是元注解。
元注解?
简单的来说就是注解的注解就是元注解,它主要用来标识你写的注解保留范围(作用范围)以及出现的位置。对于自定义注解接口的执行,需要有元注解才能解释注解。
JDK中定义了四种元注解:
@Retention:注解的保留范围,是个枚举,有如下可选值
RetentionPolicy.SOURCE:注解存在于源文件中
RetentionPolicy.CLASS:注解存在于源字节码文件中
RetentionPolicy.RUNTIME:注解存在于运行时
@Target:注解出现的位置(比如字段上、方法上等等),也是个枚举,有如下可选值
ElementType.ANNOTATION _ type 应用于注释类型。
ElementType.CONSTRUCTOR 应用于构造函数。
ElementType.FIELD 应用于字段或属性。
ElementType.LOCAL_VARIABLE 应用于局部变量。
ElementType.METHOD应用于方法级注释。
ElementType.PACKAGE 应用于包声明。
ElementType.PARAMETER 应用于方法的参数。
ElementType.TYPE应用于类的任何元素。
@Documented: 用于指定被该元 Annotation 修饰的 Annotation 类将被 javadoc 工具提取成文档.
@Inherited: 被它修饰的 Annotation 将具有继承性.如果某个类使用了被 @Inherited 修饰的 Annotation, 则其子类将自动具有该注解
5,Java内置注解:
@Override:用于修饰此方法覆盖了父类的方法;
@Deprecated:用于修饰已经过时的方法;
@SuppressWarnnings:用于通知java编译器禁止特定的编译警告。
6,自定义注解:
✿ 语法:
声明一个注解要用到的东西
- 修饰符
访问修饰符必须为public,不写默认为pubic; - 关键字
关键字为@interface; - 注解名称
注解名称为自定义注解的名称; - 注解类型元素
注解类型元素是注解中内容,可以理解成自定义接口的实现部分;
代码示例:
public @interface Info { String value() default "tracy"; boolean isDelete(); }
✿自定义注解在实际中小例子:
例如要求书写的类带上作者、时间、版本等信息,那么可能张三使用注释的方式,李四使用文档注释的方式,王五使用注解的方式,每一个人的写法和顺序可能都不一样。----leader 直接定义一个注解 @interface
✿定义注解中的属性:
基本形式:类型属性名称(); 比如:String name();
特别注意:
(1)属性值后边有一个括号!!!这个是和之前定义属性不一样的地方
(2)注解的属性的类型只能是:基本类型、String、Class、枚举、注解类型及以上类型的一维数组。
(3)默认值的关键字是default。
代码:
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface MyAnnotation { String value() default "abc"; String name() default "zhangsan"; }
注解属性定义完以后,使用注解:@MyAnnotation(value = "123",name = "lisi")
举例:使用注解
public class Test { @MyAnnotation(value = "123",name = "lisi") public static void test(){ System.out.println("这是test"); } }
举例:利用反射获取方法上的注解,并获取对应的值
public class Test { public static void main(String[] args) throws Exception { Class clazz = Class.forName("com.fours.intercepter.Test"); Method[] ms = clazz.getMethods(); for (Method m : ms) { if(m.isAnnotationPresent(MyAnnotation.class)){ String value = m.getAnnotation(MyAnnotation.class).value(); String name = m.getAnnotation(MyAnnotation.class).name(); System.out.println("value:"+value); System.out.println("name:"+name); } } } @MyAnnotation(value = "123",name = "lisi") public static void test(){ System.out.println("这是test"); } }