1.注解
注解:Annotation
定义:
不是程序本身,不是必要的,可以对程序做出解释,可以被其他程序读取
格式:以 @ 开头,后面跟注解名,还有可以加参数值
内置注解:
@Override:表示重写父类的方法
@Deprecated:表示不推荐使用的,因为它很危险或者存在更好的选择
@SuppressWarnings:用于抑制编译时的警告信息
2.@Override
示例:
class Father { public void shit() { System.out.println("今天考了多少分啊?"); } } class Son extends Father { // 表示子类的shit方法重写了父类的shit方法 // 主要的作用是编译校验,下面的方法没有实现重现编译器会报错 @Override public void shit() { super.shit(); System.out.println("考了59分!"); } }
Override
源码:
public @interface Override { }
3.@Deprecated
示例,在一个类中编写认为过时的方法:
@Deprecated public void hi() { System.out.println("我过时了!"); }
接着我们来调用此方法:
Father father = new Father(); father.hi();
所调用的方法会出现中划线,代表不推荐使用的过时方法:
@Deprecated也可以对类,字段,包,参数等场景进行使用!🎈下面是它的源码注解
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, MODULE, PARAMETER, TYPE})
4.@SuppressWarnings
示例:
// 用于抑制编译时的警告信息 @SuppressWarnings("all") public static void testSu(){ List list = new ArrayList(); }
@SuppressWarnings的作用范围取决与它所在的位置✨
源码窥探:
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE, MODULE}) @Retention(RetentionPolicy.SOURCE) public @interface SuppressWarnings { String[] value(); }
5.元注解
用于修饰注解的注解🥯
@Target:用于描述注解的使用范围,用 value 赋值
@Retention:用于描注解的生命周期,用 value 赋值,默认是 RUNTIME,SOURCE < CLASS <RUNTIME(编译的时候 < 类中 < 运行的时候)
@Documented:表示注解是否生成在 Javadoc中
@Inherited:表示子类是否继承父类的注解
@Retention
SOURCE:只在编译源码的层面生效
CLASS:记录在class文件中,当运行java程序时,JVM不会保留该注解
RUNTIME:记录在class文件中,当运行java程序时,JVM会保留该注解,程序可以通过反射获取该注解
注解是java代码审计的前置基础,同样学会注解也能帮助你更快速的看懂框架源代码🚀