android 常用注解,Android 开发小工具之:注解 Annotation

Android Support 包之一的 support-annotations是通过静态编译检测来提高代码质量的一个注解工具。里面包含了 Android 开发中常用的代码检测注解,帮助开发者提高代码质量。通过 SDK Manager下载 Android Support Repository 后,在 Gradle 中通过如下声明来使用该注解包:

dependencies {

compile ‘com.android.support:support-annotations:22.2.0’

}

该工具包含如下几种类型的代码检测:

检测参数或者返回值是否可以为 null

@Nullable 和 @NonNull 会分别检测一个变量、参数或者函数返回值是否为 null。如果一个函数的参数用 @NonNull 注解,当调用该函数指定该参数为 null 的时候,代码检测工具(Lint)会告诉你一个警告,该参数不能为 null。而 @Nullable 则表示可以为 null。例如 如下的代码表示 onCreateView 函数的返回值不为 null, 参数 context 和 attrs 也不能为 null:

import android.support.annotation.NonNull;

/** Add support for inflating the tag. */

@NonNull

@Override

public View onCreateView(String name, @NonNull Context context,

@NonNull AttributeSet attrs) {

}

资源类型注解

Android 开发中经常使用各种资源常量 R.XXX 来引用各种资源。例如 图片资源和字符串资源。这些常量都是 int 类型的,在代码检测的时候没法判断引用的资源是否有错误,比如本来需要一个字符串资源,结果在代码写的时候用了一个颜色资源,这种情况只有通过测试才能发现,有些极端情况可能测试也不容易发现。资源类型注解就是为了解决该问题的,资源注解包含如下几种:

@AnimatorRes 表明该参数、变量或者函数返回值应该是一个 Animator 类型的资源

@AnimRes 表明该参数、变量或者函数返回值应该是一个 Anim 类型的资源

@AnyRes 表明该参数、变量或者函数返回值应该是一个任意类型的资源

@ArrayRes 表明该参数、变量或者函数返回值应该是一个 Array 类型的资源

@AttrRes 表明该参数、变量或者函数返回值应该是一个 attribute 类型的资源

@BoolRes 表明该参数、变量或者函数返回值应该是一个布尔类型的资源

@ColorInt 表明该参数、变量或者函数返回值应该是一个颜色值而不是颜色资源引用,例如应该是一个 AARRGGBB 的整数值。

@ColorRes 表明该参数、变量或者函数返回值应该是一个 color 类型的资源,而不是颜色值。注意和 ColorInt 区别

@DimenRes 表明该参数、变量或者函数返回值应该是一个 dimension 类型的资源

@DrawableRes 表明该参数、变量或者函数返回值应该是一个 drawable 类型的资源

@FractionRes 表明该参数、变量或者函数返回值应该是一个 fraction 类型的资源

@IdRes 表明该参数、变量或者函数返回值应该是一个资源的 ID 类型

@IntegerRes 表明该参数、变量或者函数返回值应该是一个整数类型的资源

@InterpolatorRes 表明该参数、变量或者函数返回值应该是一个 interpolator 类型的资源

@LayoutRes 表明该参数、变量或者函数返回值应该是一个 layout 布局文件类型的资源

@MenuRes 表明该参数、变量或者函数返回值应该是一个 menu 类型的资源

@PluralsRes 表明该参数、变量或者函数返回值应该是一个 plurals 类型的资源

@RawRes 表明该参数、变量或者函数返回值应该是一个 raw 类型的资源

@StringRes 表明该参数、变量或者函数返回值应该是一个字符串类型的资源

@StyleableRes 表明该参数、变量或者函数返回值应该是一个 styleable 类型的资源

@StyleRes 表明该参数、变量或者函数返回值应该是一个 style 类型的资源

@TransitionRes 表明该参数、变量或者函数返回值应该是一个 transition 类型的资源

@XmlRes 表明该参数、变量或者函数返回值应该是一个 XML 类型的资源

例如下面的函数在调用的时候,如果用非字符串类型的 R 常量则会给出警告:

import android.support.annotation.StringRes;

public abstract void setTitle(@StringRes int resId);

线程注解类型

线程注解用来检测一个函数是否在指定类型的线程中执行。 有四个:@UiThread @MainThread @WorkerThread @BinderThread

注意: 其中 @UiThread 和 @MainThread 是可替换用的, 大部分应用中,这两个是一样的。

如果一个类中的所有函数都在同一个线程内执行,可以在 类名称上面用这个注解即可。

权限注解类型

@RequiresPermission 用来表明该函数执行需要一个或者多个权限,如果你没有声明这些权限,则会给出警告。例如:

@RequiresPermission(Manifest.permission.SET_WALLPAPER)

public abstract void setWallpaper(Bitmap bitmap) throws IOException;

@RequiresPermission(allOf = {

Manifest.permission.READ_HISTORY_BOOKMARKS,

Manifest.permission.WRITE_HISTORY_BOOKMARKS})

public static final void updateVisitedHistory(ContentResolver cr, String url, boolean real) {

}

@RequiresPermission(anyOf = {

Manifest.permission.READ_HISTORY_BOOKMARKS,

Manifest.permission.WRITE_HISTORY_BOOKMARKS})

public static final void updateHistory(ContentResolver cr, String url, boolean real) {

}

如果只要满足多个权限中的一个,用 anyOf; 如果要满足多个权限,用 allOf.

返回值是否使用检测注解

@CheckResults 用来检测函数的返回值是否被使用了,如果没有使用则说明可能不应该调用这个函数,可以给出建议使用哪个函数。例如,新的 Android SDK 中就在 checkPermission 函数中使用如下注解:

@CheckResult(suggest=”#enforcePermission(String,int,int,String)”)

public abstract int checkPermission(@NonNull String permission, int pid, int uid);

如果你调用了 checkPermission 函数,但是并没有使用其返回值,则很有可能你是想申请一个权限而不是检查是否有这个权限,所以 suggest 参数建议你使用 enforcePermission 函数来申请权限。如果你确实想检查是否有这个权限,则通常你会判断 checkPermission 的返回值来确定是否有这个权限。

确保调用 super 函数的注解

@CallSuper 来表明重写这个函数需要调用 super 父函数。如果你忘记了调用,则会提醒你。比如 Activity 的onCreate 函数需要代用 super.onCreate().

数值常量注解

@IntRange 是用来表明整数型参数的取值范围的,比如 下面的 setAlpha 函数的参数 alpha 的取值范围应该为 0 到 255,其他值都是非法的;

public void setAlpha(@IntRange(from=0,to=255) int alpha) { … }

@FloatRange 同样是表明浮点数范围的,例如:

public void setAlpha(@FloatRange(from=0.0, to=1.0) float alpha) {…}

而 @Size 是用来表明数组类型参数的长度的,可以用 @Size(min=1) 来指定数组的最小长度,@Size(2) 则表明该数组参数必须是2. 例如:、

int[] location = new int[3];

button.getLocationOnScreen(@Size(min=1) location);

创建枚举类型注解

如果一个参数、变量的取值是几个常量中的一个,则可以用 @IntDef 和 @StringDef 注解来自定义一个常量枚举类型注解。使用方式如下所示:

import android.support.annotation.IntDef;

public abstract class ActionBar {

//定义所接受的常量值

@IntDef({NAVIGATION_MODE_STANDARD, NAVIGATION_MODE_LIST, NAVIGATION_MODE_TABS})

//告诉编译器该注解不会在 .class 文件中存在

@Retention(RetentionPolicy.SOURCE)

//定义 NavigationMode 注解

public @interface NavigationMode {}

//Declare the constants

public static final int NAVIGATION_MODE_STANDARD = 0;

public static final int NAVIGATION_MODE_LIST = 1;

public static final int NAVIGATION_MODE_TABS = 2;

//Decorate the target methods with the annotation

@NavigationMode

public abstract int getNavigationMode();

//Attach the annotation

public abstract void setNavigationMode(@NavigationMode int mode);

上面的 @NavigationMode 注解使用了 @IntDef 来定义该注解所限定了一些常量值。 当你用 @NavigationMode 注解时,则说明这个参数或者函数返回值需要是 @IntDef 中定义的常量值其一 (NAVIGATION_MODE_STANDARD, NAVIGATION_MODE_LIST, 或者 NAVIGATION_MODE_TABS).

除了定义具体的常量值以外,还可以通过 flag 参数来指定一个模式,例如下面的 DisplayOptions 注解定义该类型必须满足依 DISPLAY_ 开头的一个模式。

import android.support.annotation.IntDef;

@IntDef(flag=true, value={

DISPLAY_USE_LOGO,

DISPLAY_SHOW_HOME,

DISPLAY_HOME_AS_UP,

DISPLAY_SHOW_TITLE,

DISPLAY_SHOW_CUSTOM

})

@Retention(RetentionPolicy.SOURCE)

public @interface DisplayOptions {}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/531599.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

codeforces B. Friends and Presents(二分+容斥)

题意:从1....v这些数中找到c1个数不能被x整除,c2个数不能被y整除! 并且这c1个数和这c2个数没有相同的!给定c1, c2, x, y, 求最小的v的值! 思路: 二分容斥,二分找到v的值,…

android音量键广播,音量控制键控制的音频流(setVolumeControlStream)描述

音量控制键控制的音频流(setVolumeControlStream)描述2021-01-03 16:18Android教程网 Android当开发多媒体应用或者游戏应用的时候,需要使用音量控制键来设置程序的音量大小,在Android系统中有多种音频流,感兴趣的朋友可以了解下当开发多媒体应用或者游戏应用的时候…

eclipse的使用

eclipse如何打开一个已存在的工程!先给eclipse创建一个workspace,这个workspace就是一个文件夹用来管理eclipse项目的,或者修改eclipse的workspace,选择菜单file->switch workspace->other,选择一个已经存在的workspace。将已经存在的项目导入到wo…

Android延伸布局到状态栏,Android 状态栏透明

前言:最近项目大量用到状态栏透明,网上也出现很多库可以直接拿来用,个人认为没有必要那么重引用到一个库(有木有同学和我有一样的想法),所以研究了一番,在此做个记录加强记忆也便后期查阅,如果无意中有幸能…

glassfish服务器默认的网页所在的位置

http://localhost:8080/ 默认打开的网页所在的位置 E:/glassfish-4.1/glassfish/domains/domain1/docroot/index.html 转载于:https://www.cnblogs.com/hujunzheng/p/4052920.html

华为HarmonyOS 鸿蒙,华为鸿蒙HarmonyOS2.0手机开发者Beta版正式发布

据悉,本次手机开发者Beta测试支持以下中国境内主制式手机及平板电脑。手机:全网通(5G双卡)P40 、 全网通版P40 Pro、Mate30、Mate30(5G) 、Mate30 Pro、Mate30 Pro(5G),型号清单为ANA-AN00、ELS-AN00、TAS-AL00、TAS-AN00、LIO-AL00、LIO-AN0…

http协议客户端向服务器端请求时一般需要发送的内容

out.println("GET /shopping/index.html HTTP/1.1");//请求行 包括请求方式,文件路径, http协议版本(必写)请求头.... out.println("Aceept: */*");//客户端能够处理的文件类型(不是必须&#xff…

android oneshot自动播放bug,移动端常见bug汇总001

前言本文是摘录整理了移动端常见的一些bug以及解决方案,第一篇,后面还会有持续的文章更新整理。点击样式闪动Q: 当你点击一个链接或者通过Javascript定义的可点击元素的时候,它就会出现一个半透明的灰色背景。A:根本原因是-webkit-tap-highli…

int.class 与 Integer.class

TYPE 表示的引用类型所对应的基本类型的Class对象! 转载于:https://www.cnblogs.com/hujunzheng/p/4055471.html

android uber启动动画,模仿Uber的启动画面(上)

启动画面(Splash Screen)——不但给开发者们提供了一个尽情发挥、创建有趣动画的机会,也填补了App启动时从终端慢吞吞地下载数据的时间。启动画面(动态的)对于App至关重要:它可以让用户不失兴趣地耐心等待应用完成加载。尽管现在的启动画面多种多样&…

java中产生对象的两种方式

/** 普通new对象的过程!*/Person pp new Person();System.out.println(pp);/** 利用代用参数的构造器产生对象实例!* 首先获得相应带参数的构造器,然后利用构造器产生对象实例!*/pclass Class.forName("get_class_method.P…

智慧屏用鸿蒙的生态,紧随鸿蒙OS手机版 ,智慧屏为什么对鸿蒙生态这么重要?...

原标题:紧随鸿蒙OS手机版 ,智慧屏为什么对鸿蒙生态这么重要?12 月 21 日,华为正式发布了两款智慧屏新品,智慧屏 S 系列和车载智慧屏,前者是智慧屏的新系列,后者则是新开辟的车机产品线。没有意外…

java中反射机制通过字节码文件对象获取字段和函数的方法

pclass Class.forName("get_class_method.Person");//Field ageField pclass.getField("age");//因为age成员变量是私有的,所以会产生NoSuchFieldException异常Field ageField pclass.getDeclaredField("age");//获得该对象反映此…

MySQL不能插入中文字符及中文字符乱码问题

MySQL的默认编码是Latin1,不支持中文,要支持中午需要把数据库的默认编码修改为gbk或者utf8。在安装后MySQL之后,它的配置文件不是很给力,不知道你们的是不是,反正我的是! 开始插入中文字符的时候出现如下错…

android计算距离顶部的距离,(lua版)计算距离的逻辑是从Android的提供的接口(Location.distanceBetween)中拔来的,应该是最精确的方法了...

---coding by yuangu(lifulinghanaol.com)--用于计算2个pgs之间的距离function computeDistance(lat1, lon1,lat2, lon2)-- Based on http://www.ngs.noaa.gov/PUBS_LIB/inverse.pdf-- using the "Inverse Formula" (section 4)local MAXITERS 20;-- Convert lat/lo…

codeforces C. Bits(数学题+或运算)

题意:给定一个区间,求区间中的一个数,这个数表示成二进制的时候,数字1的个数最多! 如果有多个这样的数字,输出最小的那个! 思路:对左区间的这个数lx的二进制 从右往左将0变成1&#…

密码与确认密码自动验证html,HTML确认密码

今天准备分享一个小知识点,就是确认登录界面输入户名: 输入密码: 确认密码: function validate() {var pw1 document.getElementById("pw1").value;var pw2 document.getElementById("pw2").value;if(pw1 …

实现单词大小写不敏感的正则表达式的匹配!

//实现单词大小写不敏感的正则表达式的匹配! //方法1: tmp "java java JavaJAVA"; px Pattern.compile("java", Pattern.CASE_INSENSITIVE); mx px.matcher(tmp); System.out.println(mx.replaceAll("JAVA")); //方法二…

r语言 发送邮件html,r语言读取数据的方法

R 对于基于 SQL 语言的关系型数据库有良好的支持,这些数据库既有商业数据库 Oracle、Microsoft SQL Server、IBM DB2 等,也包含在 GNUGeneral Public License (GPL) 下发布的 MySQL 等开源数据库。RMySQL 包中提供了到 MySQL 数据库的接口;RO…

正则表达式之IP地址检验

String ipRegex "^(\\d|[1-9]\\d|1\\d*|2[0-4]\\d|25[0-5])(\\.\\1){3}$"; /* * \\d|[1-9]\\d|1\\d*|2[0-4]\\d|25[0-5] * 该段的数字只有一位的时候,两位数字的时候,三位数字的时候(1开头的和2开头的) * \\1 表示向前…