Android 高版本API方法在低版本系统上的兼容性处理

Android 高版本API方法在低版本系统上的兼容性处理,第1张

概述Android版本更替,新的版本带来新的特性,新的方法。新的方法带来许多便利,但无法在低版本系统上运行,如果兼容性处理不恰当,APP在低版本系统上,运行时将会crash。

AndroID 版本更替,新的版本带来新的特性,新的方法。

新的方法带来许多便利,但无法在低版本系统上运行,如果兼容性处理不恰当,APP在低版本系统上,运行时将会crash。

本文以一个具体的例子说明如何在使用高API level的方法时处理好兼容性问题。

例子:根据给出路径,获取此路径所在分区的总空间大小。

在安卓中的文件存储使用参考中提到:

获取文件系统用量情况,在API level 9及其以上的系统,可直接调用file对象的相关方法,以下需自行计算

一般实现

就此需求而言,API level 9及其以上,调用 file.getTotalSpace() 即可,但是在API level 8 以下系统file对象并不存在此方法。

如以下方法:

/** * Returns the total size in bytes of the partition containing this path. * Returns 0 if this path does not exist. *  * @param path * @return -1 means path is null,0 means path is not exist. */public static long getTotalSpace(file path) {  if (path == null) {    return -1;  }  return path.getTotalSpace();}

处理无法编译通过

如果minSdkVersion设置为8,那么build时候会报以下错误:

Call requires API level 9 (current min is 8)

为了编译可以通过,可以添加 @Suppresslint("NewAPI") 或者 @TargeAPI(9)。

用@TargeAPI($API_LEVEL)显式表明方法的API level要求,而不是@Suppresslint("NewAPI");

但是这样只是能编译通过,到了API level8的系统运行,将会引发 java.lang.NoSuchMethodError。

正确的做法

为了运行时不报错,需要:

判断运行时版本,在低版本系统不调用此方法
同时为了保证功能的完整性,需要提供低版本功能实现

如下:

/** * Returns the total size in bytes of the partition containing this path. * Returns 0 if this path does not exist. *  * @param path * @return -1 means path is null,0 means path is not exist. */@TargetAPI(Build.VERSION_CODES.GINGERBREAD)   // using @TargeAPI instead of @Suppresslint("NewAPI")@SuppressWarnings("deprecation")public static long getTotalSpace(file path) {  if (path == null) {    return -1;  }  if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.GINGERBREAD) {    return path.getTotalSpace();  }  // implements getTotalSpace() in API lower than GINGERBREAD  else {    if (!path.exists()) {      return 0;    } else {      final StatFs stats = new StatFs(path.getPath());      // Using deprecated method in low API level system,// add @SuppressWarnings("description") to suppress the warning      return (long) stats.getBlockSize() * (long) stats.getBlockCount();    }  }}

总结

在使用高于minSdkVersion API level的方法需要:

用@TargeAPI($API_LEVEL) 使可以编译通过,不建议使用@Suppresslint("NewAPI"); 运行时判断API level; 仅在足够高,有此方法的API level系统中,调用此方法; 保证功能完整性,保证低API版本通过其他方法提供功能实现。

通过此文希望能帮助到您,解决AndroID版本API兼容性问题!谢谢大家对本站的支持!

总结

以上是内存溢出为你收集整理的Android 高版本API方法在低版本系统上的兼容性处理全部内容,希望文章能够帮你解决Android 高版本API方法在低版本系统上的兼容性处理所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1148315.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存