Android 版本适配全套指南

4,921 阅读31分钟
  • 当我在做 Android 版本适配工作的时候很痛苦,那个时候我在想有没有一个文档,将所有的关于 Android 版本适配资料全部收集起来,这样就不需要在网上东找西找了,这样就能把时间和精力投入适配工作中,每当一个新的 Android 版本发布的时候,这个想法越加强烈,终于在 Android 11 刚发布的时候筹划了这件事情,最终赶在 Android 12 刚发布的时候完成了,整个过程耗时非常漫长,因为我正在不断收集优质的资料,同时我也在不断思考,什么样的适配文档才是大家所需要的,我将适配文档简单划分成了以下几部分:

    • 官方文档

      • 新特性

      • 行为变更

    • 相关资源

      • 适配文章链接

      • 适配框架链接

适配流程

  • 这里以适配 Android 13 为例子,第一步将主模块中的 build.gradle 文件中修改 targetSdkVersioncompileSdkVersion 这两个的值
android {

    compileSdkVersion 33
    defaultConfig {
        ......
        targetSdkVersion 33
    }
}
  • 接下来在代码中做一些版本的判断,并且做好新版本的适配和旧版本的兼容
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
    ......
} else {
    ......
}
  • 到这里,大家可能有一个疑问,targetSdkVersion 和 compileSdkVersion 有啥区别?

    • targetSdkVersion:目标适配版本,告知系统 App 适配的情况,如果应用的 targetSdkVersion 比系统版本要低,那么在一些新特性上新系统会做向下兼容性处理,如果我们想要适配某个 Android 版本,必须要将 targetSdkVersion 调整到这个版本等级之上,否则在某些机型上面可能会出现一些适配异常的情况。如果我们只是简单调高了 targetSdkVersion 等级而没有适配新版本的特性,那么应用在新系统上可能会出现功能异常的情况,一般情况表现为应用崩溃或者获取不到数据。

    • compileSdkVersion:编译源码版本,我们可以通过修改这个版本等级来改变我们在代码中所看到的 Android SDK 源码的版本,同时也决定了编译器在进行代码检查时所用的版本。

  • 最后附上一张 Android 版本信息对应表

Android 版本API 等级版本代号市场占有率发布时间
Android 1333TIRAMISU暂无数据2022 年 8 月 16 日
Android 12L32S_V2暂无数据2022 年 3 月 9 日
Android 1231S20.6%2021 年 10 月 4 日
Android 1130R29.6%2020 年 9 月 9 日
Android 1029Q21.8%2019 年 9 月 3 日
Android 9.028P10.7%2018 年 8 月 7 日
Android 8.127O_MR15.5%2017 年 12 月 5 日
Android 8.026O2.6%2017 年 8 月 22 日
Android 7.125N_MR11.4%2016 年 12 月 5 日
Android 7.024N2.6%2016 年 8 月 22 日
Android 6.023M2.3%2015 年 9 月 29 日
Android 5.122LOLLIPOP_MR11.4%2015 年 3 月 10 日
Android 5.021LOLLIPOP0.7%2014 年 10 月 15 日
Android 4.419KITKAT0.6%2013 年 10 月 31 日

Google Play 应用商店政策

  • Google Play 应用在目标 API 级别方面需满足的要求(需要翻墙)

  • 每个新的 Android 版本都会引入一些变化,以便改进安全性和性能,并提升 Android 的整体用户体验。每款应用的清单文件中都有一个 targetSdkVersion 参数(也称为目标 API 级别),用以告知系统您的应用在不同的 Android 版本上分别该如何运行。

  • 将应用的目标 API 级别配置为新近的 API 级别可确保用户享受到安全性、隐私保护和性能方面的改进,同时仍然允许应用在较低版本的 Android(低至 minSdkVersion)上运行。

  • 为了向 Android 和 Google Play 用户提供安全可靠的使用体验,Google Play 要求所有应用在目标 API 级别方面都必须符合下列要求。

名词定义

新应用尚未在 Play 商店中发布的应用(例如,全新的应用)
应用更新已在 Play 商店中发布的应用的新版本
现有应用没有获得更新的已发布应用

何时必须将 Google Play 应用的目标 API 级别设为该级别?

Android 操作系统版本新应用应用更新现有应用
Android 13(API 级别 33)2023 年 8 月 1 日2023 年 11 月 1 日2024 年 11 月 1 日
Android 12(API 级别 31)2022 年 8 月 1 日2022 年 11 月 1 日2023 年 11 月 1 日
Android 11(API 级别 30)2021 年 8 月 1 日2021 年 11 月 1 日2022 年 11 月 1 日

提示:如需获得技术指导来了解如何更改应用的目标 API 级别以满足上述要求,请参阅迁移指南

何时必须将 Wear OS 应用的目标 API 级别设为该级别?

Android 操作系统版本新应用应用更新现有应用
Android 11(API 级别 30)2022 年 8 月 1 日2022 年 11 月 1 日无要求
Android 10(API 级别 29)无要求无要求无要求
Android 9(API 级别 28)2019 年 8 月 1 日2019 年 11 月 1 日无要求
  • 为帮助开发者轻松完成过渡,相比新应用,我们多给了应用更新几个月时间来满足该要求。

应用可能受到的影响

  • 您的应用若不符合目标 API 级别要求,可能会受到以下方面的影响:
应用影响
新应用您将无法在 Play 管理中心发布不符合目标 API 级别要求的 app bundle。
应用更新您将无法在 Play 管理中心提交不符合目标 API 级别要求的 app bundle 或 APK。
现有应用如果新用户的设备搭载的 Android 操作系统版本高于您的应用的目标 API 级别,那么这类用户将无法在 Google Play 上获取您的应用。也就是说,这类新用户将无法从 Google Play 中发现或安装您的应用。之前从 Google Play 中安装过这款应用的用户仍可以发现、重新安装和使用它。这类现有用户即使换用新的 Android 设备,也仍然可以使用您的应用。
  • 为帮助开发者轻松完成过渡,相比新应用,我们多给了应用更新几个月时间来满足该要求。

文档目录

Android 13.0

新特性

行为更变

官方进度

相关资源

Android 12.0 / 12L

新特性

行为变更

官方进度

相关资源

Android 11.0

概览

隐私权变更受影响的应用缓解策略
强制执行分区存储机制 以 Android 11 或更高版本为目标平台的应用始终会受分区存储行为的影响以 Android 11 或更高版本为目标平台的应用,以及以 Android 10 为目标平台且未将 requestLegacyExternalStorage 设为 true 以停用分区存储的应用更新您的应用以使用分区存储 详细了解分区存储变更
单次授权 使用单次授权功能,用户可以授予对位置信息、麦克风和摄像头的临时访问权限在 Android 11 或更高版本上运行且请求位置信息、麦克风或摄像头权限的应用在尝试访问受某项权限保护的数据之前,检查您的应用是否具有该权限 遵循请求权限方面的最佳做法
自动重置权限 如果用户在 Android 11 或更高版本上几个月未与应用互动,系统会自动重置应用的敏感权限以 Android 11 或更高版本为目标平台且在后台执行大部分工作的应用要求用户阻止系统重置应用的权限 详细了解自动重置权限
后台位置信息访问权限 Android 11 更改了用户向应用授予后台位置信息权限的方式以 Android 11 或更高版本为目标平台且需要在后台访问位置信息的应用通过对权限请求方法的多次单独调用,逐步请求在前台(粗略或精确)和后台访问位置信息的权限。必要时,说明用户授予该权限所能得到的益处 详细了解 Android 11 中的在后台访问位置信息的权限
软件包可见性 Android 11 更改了应用查询同一设备上的其他已安装应用及与之互动的方式以 Android 11 或更高版本为目标平台且与设备上的其他已安装应用交互的应用<queries> 元素添加到应用的清单 详细了解软件包可见性
前台服务 Android 11 更改了前台服务访问位置信息、摄像头和麦克风相关数据的方式在 Android 11 或更高版本上运行且在前台服务中访问位置信息、摄像头或麦克风的应用分别针对需要访问摄像头和麦克风的前台服务,声明 cameramicrophone 前台服务类型。但请注意,应用在后台运行时启动的前台服务通常无法访问位置信息、摄像头或麦克风。 详细了解前台服务的变更

新特性

行为更变

相关资源

Android 10.0

概览

隐私权变更受影响的应用缓解策略
分区存储 针对外部存储的过滤视图,可提供对特定于应用的文件和媒体集合的访问权限访问和共享外部存储中的文件的应用使用特定于应用的目录和媒体集合目录 了解详情
增强了用户对位置权限的控制力 仅限前台权限,可让用户更好地控制应用对设备位置信息的访问权限在后台时请求访问用户位置信息的应用确保在没有后台位置信息更新的情况下优雅降级 使用 Android 10 中引入的权限在后台获取位置信息 了解详情
系统执行后台 Activity 针对从后台启动 Activity 实施了限制不需要用户互动就启动 Activity 的应用使用通知触发的 Activity 了解详情
不可重置的硬件标识符 针对访问设备序列号和 IMEI 实施了限制访问设备序列号或 IMEI 的应用使用用户可以重置的标识符 了解详情
无线扫描权限 访问某些 WLAN、WLAN 感知和蓝牙扫描方法需要获得精确位置权限使用 WLAN API 和蓝牙 API 的应用针对相关使用场景请求 ACCESS_FINE_LOCATION 权限 了解详情

新特性

行为更变

相关资源

Android 9.0

新特性

行为更变

相关资源

Android 8.0 / 8.1

新特性

行为变更

相关资源

Android 7.0 / 7.1.1

新特性

行为变更

相关资源

Android 6.0

新特性

行为变更

相关资源

Android 5.0 / 5.1

新特性

行为变更

Android 4.4

新特性

行为变更