Android限制参数传递之StringDef注解的使用

2024-06-04 08:44

本文主要是介绍Android限制参数传递之StringDef注解的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1. 引言
    • 2. 注解 @StringDef
      • 2.1 举例
      • 2.2 @StringDef源码解释
    • 3. 其他类似注解 @IntDef、@LongDef
    • 4. 总结

1. 引言

在参数传递时,如果你想限制传入的参数只能是特定的几个值,该怎么做呢?
除了把参数类型定义为枚举值,还可以使用注解来限制参数只能是你规定的几个值。以下3个注解就是起到了这样的作用:

  • @StringDef 限制参数只能是规定的几个String类型的值
  • @IntDef 限制参数只能是规定的几个Int类型的值
  • @LongDef 限制参数只能是规定的几个Long类型的值

2. 注解 @StringDef

@StringDef: 限制参数只能是规定的几个String类型的值。它作用到注解身上,接收你规定的几个字符串作为特定的值。

2.1 举例

在Java中,自定义注解 @ServiceName 来表示想要获取的系统服务的名字👇。

   @Retention(SOURCE)@StringDef({"power","window","layout_inflater"})public @interface ServiceName {} 

上面代码声明了 @ServiceName 注解,并且限制了被该注解修饰的参数只能是 “power”、“window”、“layout_inflater”。

接下来使用该注解,发挥作用!
比如,封装一个获取系统服务的方法,传入的参数为系统服务的名字。

   public Object getSystemService(@ServiceName String name) {// 省略...获取服务}																																										

外界在调用的时候,由于 String name 前面有@ServiceName 的修饰,因此只能传入 "power"、"window"、"layout_inflater" 这几个字符串。

否则的话,就会提示报错:👇
报错
包错信息已经很明显:传入的参数必须是 "power"、"window"、"layout_inflater"其中之一。


2.2 @StringDef源码解释

从 @StringDef 的源码也可以看出它的作用,下面是源码:👇

/*** Denotes that the annotated String element, represents a logical* type and that its value should be one of the explicitly named constants.* <p>* Example:* <pre><code>*  &#64;Retention(SOURCE)*  &#64;StringDef({*     POWER_SERVICE,*     WINDOW_SERVICE,*     LAYOUT_INFLATER_SERVICE*  })*  public @interface ServiceName {}*  public static final String POWER_SERVICE = "power";*  public static final String WINDOW_SERVICE = "window";*  public static final String LAYOUT_INFLATER_SERVICE = "layout_inflater";*  ...*  public abstract Object getSystemService(@ServiceName String name);* </code></pre>*/
@Retention(SOURCE)
@Target({ANNOTATION_TYPE})
public @interface StringDef {/** Defines the allowed constants for this element */String[] value() default {};/*** Whether any other values are allowed. Normally this is* not the case, but this allows you to specify a set of* expected constants, which helps code completion in the IDE* and documentation generation and so on, but without* flagging compilation warnings if other values are specified.*/boolean open() default false;
}

上文1.1 的举例,也是来源于源码注释中的举例。

3. 其他类似注解 @IntDef、@LongDef

与 @StringDef 注解类似,作用都是限制参数传递时,指定特定的几个值,防止外界传入不合理的值。区别是修饰的类型的不同,@IntDef、@LongDef分别代表了 Int 和 Long 类型。

这样在编译的阶段就能发现错误,而不是到运行时才出现预期之外的错误。

4. 总结

使用注解 @StringDef、@IntDef、@LongDef可以限制参数只能是规定的几个值,防止外界传入不合理的值。

这种用法是规范编程的体现,可以尝试用起来,让你的代码看起来专业而优雅。

感谢支持~

这篇关于Android限制参数传递之StringDef注解的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1