随着Android SDK版本不断的迭代更新,在新的SDK上总是会出现让人眼前一亮非常方便好用的API。但是这些新的API呢在低版本的SDK上是没有的,所以当我们的minSdkVersion的版本低于新API所在的版本时,我们直接使用新API在编译时会出现报错。如果只是想解决编译报错的问题呢,Android给我们提供了两种注解的方式避免编译时报错:
这两种方法又有什么区别呢?
SupressLint很显然的意思是忽略Lint检查,对于我们使用高版本API来说,可以使用@SuppressLint("NewApi")的方式让Lint在编译时忽略所调用API对版本的要求。而@TargetApi是忽略特定版本的API调用报错。
举个栗子:当你的项目minSdkVersion=9,你想使用API 11的新的方法时。此时,使用@TargetApi(11)和@SuppressLint("NewApi")的效果一样,代码都不会报错。但是如果你使用了Api 19才出现的新的方法时,在使用@TargetApi的方法中还是会给你报错,而在另一个方式中依然不会报错。
那这么讲使用@SuppressLint("NewApi")就更好了?
当然不是啦!我们要清楚一点,使用上面两种注释的方式只是让lint在编译时不再报错,在低版本的手机系统中,如果直接使用高版本的API肯定会报:“NoSuchMethod”的Crash的。
所以正确的做法应该是在注解的方法中,做版本判断,在低版本中依然使用老的方式处理。版本判断时我们需要判断具体的版本号,比如
1@TargetApi(9)
2public void doSomeThing() {
3 if(Build.VERSION.SDK_INT >= 9) {
4 // 此时我们正常使用API 9的方法,如果这里误使用了Api 11中的方法,编译时就会报错
5 // 提醒我们只是引入API 9中的方法
6 } else {
7 // TODO 使用老的方式
8 }
9}
10
11@SuppressLint("NewApi")
12public void doOthers() {
13 if(Build.VERSION.SDK_INT >= 9) {
14 // 此时我们正常使用API 9的方法,如果这里误使用了Api 11中的方法,编译不会报错
15 // 那么运行在低版本中将会引发Crash的风险
16 } else {
17 // TODO 使用老的方式
18 }
19}
所以,我们推荐使用@TargetApi的方式比较安全。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有