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

相关文章

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准