Annotation(一) :系统内建的Annotation、自定义Annotation

2024-04-22 23:38

本文主要是介绍Annotation(一) :系统内建的Annotation、自定义Annotation,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(最近在学习李兴华的java视频,遂写下学习笔记以铭之)

简介

     Annotation,被称为注释,即:使用注释的方式添加程序的一些信息。

    Java.lang.annotation.Annotation是所有Annotation都必须实现的接口。


系统自建的三种Annotation

  • @override:覆写的Annotation
  • @Deprecated:不赞成使用的Annotation
  • @SuppressWarning:压制安全警告的Annotation

基本使用

    (1) @override

        表示方法覆写的正确性,例:

class Person{public String getInfo(){		// 取得信息return "这是一个Person类。" ;}
};
class Student extends Person{	// 继承此类@Overridepublic String getinfo(){	// 覆写方法return "这是一个Student类。" ;}
};
public class OverrideAnnotationDemo01{public static void main(String args[]){Person per = new Student() ;System.out.println(per.getInfo()) ;	// 输出信息}
};

(2) @Deprecated

      使用@Deprecated注释的Annotation本事是不建议使用的一个操作

@Deprecated			// 声明不建议使用的操作
class Demo{public String getInfo(){return "这是一个Person类。" ;}
};
public class DeprecatedAnnotationDemo02{public static void main(String args[]){Demo d = new Demo() ;System.out.println(d.getInfo()) ;}
};
(3) @SuppressWarning

 用于压制警告信息

以泛型为例,在泛型中如果没有指定泛型类型,则使用时肯定出现安全警告

class Demo<T>{private T var ;public T getVar(){return this.var ;}public void setVar(T var){this.var = var ;}
};
public class SuppressWarningsAnnotationDemo01{@SuppressWarnings("unchecked")public static void main(String args[]){Demo d = new Demo() ;d.setVar("Troy") ;System.out.println("内容:" + d.getVar()) ;}
};

以上只是压制了一个警告信息,如果要压制多个警告信息,只需要以数组的形式出现即可

@Deprecated
class Demo<T>{private T var ;public T getVar(){return this.var ;}public void setVar(T var){this.var = var ;}
};
public class SuppressWarningsAnnotationDemo02{@SuppressWarnings({"unchecked","deprecation"})public static void main(String args[]){Demo d = new Demo() ;d.setVar("Troy") ;System.out.println("内容:" + d.getVar()) ;}
};
@SuppressWarning中关键字

No.关键字描述
1deprecated使用了不赞成使用的类或方法的警告
2unchecked使用了未检查的转换时警告
3fallthrough当swithch块直接往下执行而没有break时的警告
4path当类路径和源文件路径中有不存在路径的警告
5serial当在可序列化的类中不存在serialVersionId出现的警告
6finally任何finally子句无法完成出现的警告
7all关于以上所有出现的警告

在设置注释信息时,是以key->value的形式出现的,所以也可以直接使用value={"unchecked","Deprecated"}的方式设置

  

 

定义简单的Annotation

Annotation定义格式:

   [public] @interface Annotation名称 {

           数据类型    变量名称();

}

例: 

public @interface MyDefaultAnnotationNoneParam{}

 之后就可以在程序中使用 "@Annotation名称"的格式

@MyDefaultAnnotationNoneParam
class Demo{
};
这就表示在Demo类上使用Annotation


可以在Annotation使用成员接收参数

例如:

public @interface MyDefaultAnnotationSingleParam{public String value() ;	// 接收设置的内容
}
在使用的时候必须清楚的指定变量的内容

@MyDefaultAnnotationSingleParam("Troy")
class Demo{
};

也可以明确的指定变量赋值给哪个参数

@MyDefaultAnnotationSingleParam(value="Troy")
class Demo{
};

既然可以使用一个参数,就可以使用多个参数

public @interface MyDefaultAnnotationMoreParam{public String key() ;public String value() ;	// 接收设置的内容
}

此Annotation在使用的时候,必须明确指定key和value

@MyDefaultAnnotationMoreParam(key="科大",value="Troy")
class Demo{
};

参数也可以是一个数组

public @interface MyDefaultAnnotationArrayParam{public String[] value() ;	// 接收设置的内容
}

接收的类型是一个数组类型,则需传入一个数组,使用方式类似于SuppressWarning...

@MyDefaultAnnotationArrayParam(value={"MLDN","李兴华"})
class Demo{
};

可以为Annotation指定默认参数

在声明的时候使用default即可

public @interface MyDefaultAnnotationValue{public String key() default "科大" ;	// 指定好了默认值public String value() default "Troy" ;	// 指定好了默认值
}
则在使用此Annotation时不必传入参数

@MyDefaultAnnotationValue
class Demo{
};

使用枚举来指定Annotation的取值范围

   在操作中,有时需要固定Annotation的取值范围,只能取固定几个值,这时便可以利用枚举.

public enum MyName{	// 定义枚举类型a,b,c ;
}
public @interface MyDefaultAnnotationEnum{public MyName name() default MyName.a ;	// 指定默认值
}
那么在使用此Annotation时,则必须从MyName中取值。

@MyDefaultAnnotationEnum(name=MyName.b)	// 只能从固定的枚举中取内容
class Demo{
};

Retention和RetentionPolicy

    在Annotation中可以使用Retention定义一个Annotation的保存范围,此Retention的定义如下:

@Documented
@Retention(value=RUNTIME)
@Target(value=ANNOTATION_TYPE)
public @interface Retention {RetentionPolicy value();
}
   以上Retention的定义中包含了一个RetentionPolicy变量,该变量用于指定Annotation的保存范围,该变量包含了三种取值范围

No.取值描述
1SOURCE此Annotation的信息只会保留在程序的源文件中,不会保存在编译好的类文件中
2CLASS此Annotation会保留在源文件和编译好的class文件中,而不会加载到JVM中,默认为此范围。
3RUNTIME此Annotation会保留在源文件,编译好的class文件,在运行时会被加载到JVM中

额外需要注意的RUNTIME范围,因为在执行的时候起作用,可以与反射搭配起来使用。

例:

import java.lang.annotation.Retention ;
import java.lang.annotation.RetentionPolicy ;
@Retention(value=RetentionPolicy.RUNTIME)	// 表示此Annotation在运行时有效
public @interface MyDefaultRententionAnnotation{public String name() default "Troy" ;
}

内建的Annotation的RetentionPolicy:

  • Override中使用的是SOURCE,只能在源文件中出现
  • Deprecated中使用的是RUNTIME,可以在执行时出现
  • SupressWarning中使用的SOURCE,只能在源文件中出现

这篇关于Annotation(一) :系统内建的Annotation、自定义Annotation的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/927188

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1