注解:对程序进行解释(但不是注释)
1.内置注解:
@Override:定义在java.lang.Override中,此注释只适用于修辞方法,表示一个方法声明打算重写超类红的另一个方法的声明
@Deprecated:定义在java.lang.Deprecated中,次注释可以用于修辞方法,属性,类,表示不鼓励程序员使用这样的元素,通常是因为它很危险或者存在根号的选择
@SuppressWarnings:用于抑制编译时的警告信息
2.源注解:
负责注解其他注解,java定义的4个标准的meta-annotion类型,他们用来提供对1其他annotion类型做说明
(1)@Target:用于描述注解的使用范围(被描述的注解可以用在什么地方)
(2)@Retention:表示需要在什么级别保存该注释信息,用于描述注解的生命周期(表示我们的注解在什么地方还有效)
(3)@Document:说明该注释被包含在javadoc中
(4)@Inherited:说明2子类可以继承父类中的该注释
3.自定义注解:
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
public class Test1 {
@MyAnnotion(name = "梵蒂冈的",schools = "西南大学")
public void test(){
System.out.println("jjaa");
}
public static void main(String[] args) {
Test1 test1 = new Test1();
test1.test();
}
}
@Target({ElementType.TYPE,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotion{
//default 为定义默认值
String name() default "";
int age() default 0;
int id() default -1; //如果默认值为-1,则不存在
String[] schools() default "";
}
@Target({ElementType.TYPE,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotion{
String value();//如果只有一个值,最好使用value
}