VERSION.SDK_INT介绍

本文深入探讨了Android SDK_INT常量的含义、获取方式及用途,并提供了实例代码来展示如何利用此常量进行平台兼容性判断,确保应用程序在不同版本的Android系统上运行稳定。

看到VERSION.SDK_INT不禁诧异,这是何物?!

看API的定义,如下:

[java]  view plain copy print ?
  1. public static final int SDK_INT  
  2.   
  3. Since: API Level 4  
  4. The user-visible SDK version of the framework; its possible values are defined in Build.VERSION_CODES.  

原来是一个常量值。但是这个常量值可以根据系统的不同而不同哟!为了揭开其神秘的面纱,将源码ctrl如下:

[java]  view plain copy print ?
  1. /** 
  2.   * The user-visible SDK version of the framework; its possible 
  3.   * values are defined in {@link Build.VERSION_CODES}. 
  4.   */  
  5.   public static final int SDK_INT = SystemProperties.getInt(  
  6.                "ro.build.version.sdk"0);  

可以看出,获取系统属性,类似Java中获取系统属性值。

研究一下 SystemProperties 这个类,知道该类没有在API中出现,android并没有开放这个API接口。
VERSION.SDK_INT 常量,在开发过程中还是比较有用的,为了做到平台兼容性,可以使用该值做一些判断,防止API调用过时或者消失。

示例:

[java]  view plain copy print ?
  1. int currentVersion = android.os.Build.VERSION.SDK_INT;  
  2. if(currentVersion == android.os.Build.VERSION_CODES.ECLAIR_MR1) {  
  3.     // 2.1  
  4. else if(currentVersion == android.os.Build.VERSION_CODES.FROYO) {  
  5.     // 2.2  
  6. else if(currentVersion == android.os.Build.VERSION_CODES.GINGERBREAD) {  
  7.     // 2.3  
  8. else if(currentVersion == android.os.Build.VERSION_CODES.HONEYCOMB) {  
  9.     // 3.0  
  10. }  


还如,判断如果设备不是3.0(平板操作系统)的话,就设置不显示标题:

[java]  view plain copy print ?
  1. if (VERSION.SDK_INT != 11) {  
  2.       getWindow().requestFeature(Window.FEATURE_NO_TITLE);  
  3. }  

这些常量位于android.os.Build.VERSION_CODES这个内部类中:

 
在 Android Studio 中,`Build.VERSION.SDK_INT` 是一个静态变量,代表运行该应用的手机系统的 SDK 版本,这个值是通过 native 方法,在 `Build` 类加载时获得 [^1]。 ### 使用方法 `Build.VERSION.SDK_INT` 常被用于条件判断,以根据不同的 Android 系统版本执行不同的代码逻辑。以下是几种常见的使用场景及示例代码: #### 1. 权限请求 在 Android 6.0(API 级别 23,对应 `Build.VERSION_CODES.M`)及以上版本,应用需要在运行时请求某些敏感权限。可以使用 `Build.VERSION.SDK_INT` 来判断是否需要进行运行时权限请求: ```java private static final int PERMISSION_REQUEST_CODE = 1; if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) { if (checkSelfPermission(Manifest.permission.READ_EXTERNAL_STORAGE) == PackageManager.PERMISSION_DENIED) { Log.d("permission", "permission denied to READ_EXTERNAL_STORAGE - requesting it"); String[] permissions = {Manifest.permission.READ_EXTERNAL_STORAGE}; requestPermissions(permissions, PERMISSION_REQUEST_CODE); } } ``` #### 2. 功能适配 不同的 Android 版本可能会有不同的系统特性或 API 支持。可以使用 `Build.VERSION.SDK_INT` 来确保在特定版本及以上才使用某些功能: ```java if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { Window window = getWindow(); window.setFlags( WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS, WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS ); } ``` #### 3. 解决编译问题 当项目的 `compileSdkVersion` 较低,而代码中使用了较新版本的 `Build.VERSION_CODES` 常量时,会出现编译错误。可以使用整数值代替 `Build.VERSION_CODES` 常量,以确保代码能在较低的 `compileSdkVersion` 下编译通过: ```java // 假设 compileSdkVersion = 31,而 Build.VERSION_CODES.TIRAMISU 在 SDK 31 中未定义 if (Build.VERSION.SDK_INT >= 33) { // Android 13 及以上才执行的代码 } ``` ### 相关介绍 `Build.VERSION.SDK_INT` 用于获取设备当前运行的 Android 系统的 SDK 版本号。而 `Build.VERSION_CODES` 是 Android SDK 中的一个类,包含了一系列代表不同 Android 版本的常量,如 `Build.VERSION_CODES.KITKAT` 代表 Android 4.4,`Build.VERSION_CODES.M` 代表 Android 6.0 等 [^1]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值