高版本api在低版本中的兼容
Posted 世界很大,风住过这里
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高版本api在低版本中的兼容相关的知识,希望对你有一定的参考价值。
直接上例子,看如何避免crash.
eg:根据给出路径,获取此路径所在分区的总空间大小。
文档说明:获取文件系统用量情况,在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(); } } }
总结:
- 用
@TargeApi($API_LEVEL)
使可以编译通过, 不建议使用@SuppressLint("NewApi")
; - 运行时判断API level; 仅在足够高,有此方法的API level系统中,调用此方法;
- 保证功能完整性,保证低API版本通过其他方法提供功能实现。
以上是关于高版本api在低版本中的兼容的主要内容,如果未能解决你的问题,请参考以下文章
android高版本程序能在低版android系统上运行吗?
java jdk 1.8如何向下兼容,有个时候写高版本的时候maven 在低版本中没法编译?
window.getComputedStyle能够获取元素的实际样式,但是低版本的ie8及以下不支持,如何在低版本的ie上兼容类似的功能