欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android 高版本API方法在低版本系統(tǒng)上的兼容性處理

 更新時間:2016年09月09日 10:35:39   作者:MrlLee  
本文主要介紹Android 高版本API方法在低版本系統(tǒng)上的兼容性處理的問題,這里提供了解決辦法,并附簡單示例,來詳細(xì)說明解決問題步驟,有需要的小伙伴可以參考下

Android 版本更替,新的版本帶來新的特性,新的方法。

新的方法帶來許多便利,但無法在低版本系統(tǒng)上運(yùn)行,如果兼容性處理不恰當(dāng),APP在低版本系統(tǒng)上,運(yùn)行時將會crash。

本文以一個具體的例子說明如何在使用高API level的方法時處理好兼容性問題。

例子:根據(jù)給出路徑,獲取此路徑所在分區(qū)的總空間大小。

在安卓中的文件存儲使用參考中提到:

獲取文件系統(tǒng)用量情況,在API level 9及其以上的系統(tǒng),可直接調(diào)用File對象的相關(guān)方法,以下需自行計(jì)算

一般實(shí)現(xiàn)

就此需求而言,API level 9及其以上,調(diào)用 File.getTotalSpace() 即可, 但是在API level 8 以下系統(tǒng)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設(shè)置為8,那么build時候會報以下錯誤:

Call requires API level 9 (current min is 8)

為了編譯可以通過,可以添加 @SuppressLint("NewApi") 或者 @TargeApi(9)。

用@TargeApi($API_LEVEL)顯式表明方法的API level要求,而不是@SuppressLint("NewApi");

但是這樣只是能編譯通過,到了API level8的系統(tǒng)運(yùn)行,將會引發(fā) java.lang.NoSuchMethodError。

正確的做法

為了運(yùn)行時不報錯, 需要:

判斷運(yùn)行時版本,在低版本系統(tǒng)不調(diào)用此方法
同時為了保證功能的完整性,需要提供低版本功能實(shí)現(xiàn)

如下:

/**
 * 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();
    }
  }
}

總結(jié)

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

  1. 用@TargeApi($API_LEVEL) 使可以編譯通過, 不建議使用@SuppressLint("NewApi");
  2. 運(yùn)行時判斷API level; 僅在足夠高,有此方法的API level系統(tǒng)中,調(diào)用此方法;
  3. 保證功能完整性,保證低API版本通過其他方法提供功能實(shí)現(xiàn)。

通過此文希望能幫助到您,解決Android版本API兼容性問題!謝謝大家對本站的支持!

相關(guān)文章

最新評論