java基础之注解示例详解

网友投稿 268 2022-11-12

java基础之注解示例详解

目录定义作用注解与注释的区别JDK内置的标准注解自定义注解@Target属性

定义

注解也叫原数据,它是JDK1.5及之后版本引入的一个特性,它可以声明在类、方法、变量等前面,用来对这些元素进行说明。

作用

生成文档:通过代码里标识的注解生成doc文档【生成doc文档】

代码分析:通过代码里标识的注解对代码进行分析【反射】

编译检查:通过代码里标识的注解让编译器能够实现基本的编译检查【Override】

注解与注释的区别

注解是给编译器看的,注释是给程序员看的。

JDK内置的标准注解

@Override

表示该方法是覆盖父类的,如果某个方法父类中并没有,且该方法使用了@Override,则会报错

@Deprecated

表示该方法已经过时,但还是可以用

@SuppressWarnings

压制警告

一般用在类的前面,传递参数"all",表示压制该类的所有警告

这是父类代码

public class Fu {

public void eat(){

System.out.println("Fu 吃......");

}

}

这是子类代码

@SuppressWarnings("all")//压制该类下的所有警告

public class Zi extends Fu{

@Override //表示该方法是重写父类的

public void eat(){

System.out.println("Zi eat......");

}

@Deprecated //表示该方法已经过时

public void work(){

}

}

下面是主类

自定义注解

格式:

​ 元注解

​ public @interface 注解名称{

​ 属性列表

​ }

注解本质其实上是一个接口,该接口默认继承Annotation接口

public interface 注解名称extends java.lang.annotation.Annotation {}

元注解

注解的注解就是元注解

下面是@Override注解的源码,我们可以看到在@Override的前面还有一些注解,下面我们来介绍一下这些注解

我们需要掌握5种元注解:

@Target

指明了注解可以在哪里使用

参数ElementType取值

​ TYPE:指明注解可以使用在类上

​ METHOD:指明注解可以使用在方法上

​ FIELD:指明注解可以使用在成员变量上

@Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD}) //当{}里面的内容只有一个时,{}可以省略

public @interface PersonWrite {

int age();

String name() default "22";

}

@Retention()

指明注解被保留的阶段:

注解保留到源代码阶段

@Retention(RetentionPolicy.SOURCE)

注解保留到编译阶段

@Retention(RetentionPolicy.CLASS)

注解1保留到运行阶段

@Retention(RetentionPolicy.RUNTIME)

@Documented

标识注解被抽取到doc文档中

@Inherited

标识注解被子类继承

属性

注解中的属性其实是抽象方法

属性的返回类型只能是下面几种类型:

基本数据类型

String

枚举

注解

以上类型的数组

如果注解里面定义了属性(接口),在使用时要给属性赋值

如果定义属性时使用default给属性赋值,则在使用注解时可以不给该属性赋值(当然也可以重新赋值)如果注解只有一个,且注解的名称是value,则使用时传参直接写参数即可,不用写属性名数组赋值时,使用{}包裹,如果数组中只有一个值,则{}可以省略

下面是自定义的注解:

@Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD})

@Retention(RetentionPolicy.RUNTIME)

public @interface PersonWrite {

int age();

String name() default "李四";

}

下面是该注解的使用:

package Java高级特性.注解;

@PersonWrite(age = 222)

public class Main {

public static void main(String[] args) {

Zi zi = new Zi();

zi.work();

}

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Nginx中AWStats日志分离的详细部署
下一篇:TarsGo新版本发布,支持protobuf,zipkin和自定义插件
相关文章

 发表评论

暂时没有评论,来抢沙发吧~