注释: java不会编译注释的内容,注释给程序员看的。
注解: 它是程序看,当程序看到这个注解时,就应该解析它。
譬如: @Controller @Override
注解的分类:
1. 预定义注解
2. 自定义注解
3. 元注解
1、 预定义注解---了解
预定义注解就是JDK自带的一些注解,该注解被JVM而解析。
1. @Override: 重写得注解。符合重写得规则。
2. @Deprecated: 表示已过时。
3. @SuppressWarnings: 表示压制警告。
4. @FunctionInterface: 表示函数式接口。表示该接口中有且仅有一个抽象方法。
2、自定义注解。---初级
语法:
public @interface 注解名{
//注解属性
}
使用自定义注解:
类 方法 属性 加@注解名
package demo09;
public class Test09 {
public static void main(String[] args) {
Info i=new Info();
i.name="张三";
i.show();
}
}
//定义好注解了
@interface My{
//注解属性
}
//使用注解
@My
class Info{
@My
public String name;
@My
public void show(){
System.out.println("show================="+name);
}
}
注解本身没有任何意义,它只有被解析了,才会赋予真正的意义。
我们后会使用反射来对象注解进行解析。
像:@Override 它被JVM解析,从而使其具有相应的意义。
@Controller @RequestMapping 它被Spring框架解析,所以具有相应的意义。
3、元注解
-
定义在注解上的注解称为元注解。
@Controller它只能加在类上 @Override它只能加在方法上。
原因它使用了元注解可以设置注解使用的位置。
1. @Target(value=可以取下面这些内容): 作用限制注解使用得位置。
/** 表示可以作用在类,接口,枚举 */
TYPE,
/** 属性 */
FIELD,
/** 普通方法上 */
METHOD,
/** 方法参数 */
PARAMETER,
/** 构造方法上 */
CONSTRUCTOR,
/** 局部变量 */
LOCAL_VARIABLE
2. @Retention: 注解什么时候生效。默认时源码 java经历了那些阶段。
源码阶段-->字节码阶段--->运行阶段
/**
* 源码时生效
*/
SOURCE,
/**
* 字节码时生效
*/
CLASS,
/**
* 运行时生效。
* 在JVM内存中还有该注解。
都会被设置为运行时有效
*/
RUNTIME
3. @Documented 当生产API文档时该注解还存在。
4. @Inherited 是否运行被子类继承。
4、自定义注解---高级
思考: @RequestMapping("/hello") 因为它定义@RequestMaping注解中有属性。
@interface 注解名{ 数据类型 属性名() default 默认值; }
数据类型: 基本类型,字符串类型,枚举类型【常量】,注解类型,数组类型【必须是上面这些类型的数组】
练习:
自定义注解: 该注解中有String[] name()和value()属性,name有默认值。
该注解只能在类上使用,而且在运行时有效。
package zy05;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
public class Test05 {
public static void main(String[] args) {
Info i=new Info();
i.n="123456";
i.show();
System.out.println();
}
}
//该注解只能在类上使用
@Target(value = {ElementType.TYPE})
//注解在运行时有效
@Retention(value = RetentionPolicy.RUNTIME)
//自定义注解
@interface My{
String[] name() default {"hello","张三"};
String value();
}
//使用注解
@My(value = "李四")
class Info{
public String n;
public void show(){
System.out.println("show===="+n);
}
}