Android compileSdkVersion、minSdkVersion、targetSdkVersion的区别

本文解释了Android开发中的关键版本设置,如compileSdkVersion、minSdkVersion和targetSdkVersion的作用,重点讲解了targetSdkVersion如何确保兼容性和新特性利用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  Android手机都有一个运行的系统版本。系统和应用程序类似,系统版本和打包系统的targeSdkVersion版本一致,App在Android手机上可以调用所对应SDK中的Api。

一、compileSdkVersion

compileSdkVersion字面意思“编译SDK版本”。这个是build.grade通过compileSdkVersion告诉grade使用那个SDK来编译APP程序。

SDK在更新过程中,会出现一些Api被弃用(维护SDK稳健性以及冗余等)。在新的系统版本中,这些方法调用就会出现失效的问题。compileSdkVersion就是为了处理APP出现这个问题而存在。

compileSdkVersion版本会在项目编译的过程中,把deprecated的一些Api以警告或者报错的形式显示出来。

compileSdkVersion版本尽量和最新的SDK一致。(避免在新版本手机上功能缺失)

二、minSdkVersion

minSdkVersion是应用可以运行的Android SDK的最低版本。用来判断用户设备是否可以安装某个应用的标志之一。

APP使用的Library如果有自己的minSdkVersion,则APP本身设置的minSdkVersion必需大于等于这些库的 minSdkVersion。

maxSdkVersion是应用可以运行的Android SDK的最高版本。一般不指定,因为系统升级时如果超过maxSdkVersion可能会出现APP被移除的问题。

三、targetSdkVersion

  直观翻译是“目标版本”,它的作用是兼容旧的api。targetSDKVersion的版本大小可以决定是否采用新的特性还是维持老的特性。因为在手机系统升级之后,Android SDK在提供新特性的同时会兼容一下老特性,会根据APP targetSDKVersion的版本号来选择使用哪个特性。只要targetSDKVersion没有变化,即使手机系统升级了,还是采用老特性。

  举个例子,Android 8.0/8.1 系统规定了透明的activity 不能固定方向,否则抛出异常。我们暂时不管google设计的目的何在,先想想假设我们的app使用了透明的activity,且固定了方向,在Android 8.0版本以下运行正常,当我们运行在Android 8.0/8.1系统上,结果如何会如何呢?很不幸,直接crash。对于我们来说,这结果当然不能接受了,我一个好端端的app,你升级个Android 系统直接让我的app挂掉,没有转圜的余地,不科学啊

因此,google想出了一个办法,那就是通过targerVersion字段来区分同一api在不同系统上的行为。

总结

  对于同一个API(方法),新版本的系统更改了它的内部实现逻辑,新逻辑可能会影响之前调用此API的App,为了兼容此问题,引入targetSdkVersion。当targetSdkVersion>=xx(某个系统版本)时再生效其新修改的逻辑,否则还是沿用之前的逻辑。换句话说:如果你更改了targetSdkVersion值,说明你已经测试过兼容性问题了。

maxSdkVersion >= buildToolsVersion >= compileSdkVersion>= targetSdkVersion >= minSdkVersion

### 修改 `targetSdkVersion` 的方法 在 Android Studio 中调整项目的 `targetSdkVersion` 值是一个常见的需求,可以通过编辑 `build.gradle` 文件来实现。以下是具体操作: #### 1. 找到并打开 `build.gradle (Module: app)` 文件 该文件通常位于项目目录下的 `app/build.gradle` 路径中。 #### 2. 定位 `defaultConfig` 部分 在此部分可以找到关于 SDK 版本的相关配置项,包括但不限于 `compileSdkVersion`, `minSdkVersion`, 和 `targetSdkVersion`。 #### 3. 将 `targetSdkVersion` 设置为 30 将原有的 `targetSdkVersion 31` 替换为 `targetSdkVersion 30`[^2]。例如: ```gradle android { ... defaultConfig { ... minSdkVersion 14 targetSdkVersion 30 // 修改此行为目标版本 } } ``` 如果存在多个产品风味(product flavors),则需要逐一检查这些风味中的 `targetSdkVersion` 是否也需要同步修改。 #### 4. 同步 Gradle 文件 完成上述更改后,点击 Android Studio 工具栏上的 **Sync Now** 按钮以应用新的配置。Gradle 构建工具会重新加载依赖关系,并验证新设置的有效性。 --- ### 注意事项 - 如果项目中有其他模块也定义了自己的 `targetSdkVersion`,需确保它们保持一致或按需单独调整。 - 更改 `targetSdkVersion` 可能会影响某些功能的行为,尤其是涉及权限管理的部分。因此建议测试应用程序的功能完整性。 - 若使用的是较旧版的 Android 插件(如低于 7.x),可能还需要手动更新插件版本以支持最新的 Gradle 功能[^3]。 --- ### 示例代码片段 以下是一份完整的 `build.gradle` 配置示例,展示了如何正确设置 `targetSdkVersion`: ```gradle android { compileSdkVersion 30 // 确保与 targetSdkVersion 协调工作 defaultConfig { applicationId "com.example.myproject" minSdkVersion 14 targetSdkVersion 30 // 设定为目标版本 versionCode 1 versionName "1.0" } } ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值