Android - API Levels-<uses-sdk android:minSdkVersion="8" />

API级别详解
本文详细解释了Android平台中的API级别概念,介绍了如何利用API级别确保应用与不同版本的Android系统兼容。文章还阐述了如何在应用清单文件中设置API级别,以避免因版本不兼容导致的问题。
转自:http://www.cnblogs.com/zziss/archive/2012/02/13/2350032.html

API级别是什么

当你开发你的Android应用程序时,了解该平台API变更管理的基本方法和概念是很有帮助的。同样的,知道API级别标识以及该标识如何保障你的应用与实际硬件设备相兼容对于开发及后续的发布、维护都是有益的。API级别是一个整数值,它唯一标识了一个具体版本的Android平台,及其框架的API的版本。

Android平台提供了一套框架API,使得应用程序可以与系统底层进行交互。该框架API由以下模块组成:

一组核心的包和类
清单(manifest)文件的XML元素和属性声明
资源文件的XML元素和属性声明及访问形式
各类意图(Intents)
应用程序可以请求的各类授权,以及系统中包含的授权执行

每个Android平台的后续版本会包括它提供的更新的Andr​​oid应用程序框架的API。

该框架的API的更新设计,使高版本的API与早期版本兼容。也就是说,在新版本API中大多数都是新增功能,和引进新的或替代的功能。作为API的部分升级,老的替换的部分已过时,但不会从新版本中删除,使得已有的应用程序仍然可以使用它们。在极少数情况下,旧版本API的部分可能被修改或删除,通常这种变化是为了保障API的稳定性及应用程序或系统的安全。所有其他早期版​​本的API将不做修改的保留。

一个Android平台提供的框架API,被指定一个整数标识符,称为“API级别”。每一个版本的Android平台只支持有一个API级别,虽然该支持是隐含地包括了所有早期的API级别(一直到API级别1级)。 Andr​​oid平台的最初版本提供的框架API级别是1级,随后的版本依次递增。

下表说明了具体平台版本和支持的API级别的对应关系。

平台版本


API级别

Android 3.0


11

Android 2.3.3


10

Android 2.3


9

Android 2.2


8

Android 2.1


7

Android 2.0.1


6

Android 2.0


5

Android 1.6


4

Android 1.5


3

Android 1.1


2

Android 1.0


1



在Android中使用API级别

API级别标识为保证用户和应用程序开发者的最佳体验,起了关键作用:

它让Android平台可以描述它支持的框架API的最高版本
它让应用程序可以描述它需要的框架API版本
它使得系统可以在硬件设备上安装应用程序时能够检查版本是否匹配,使得版本不兼容的应用程序不会被错误安装在设备之上.

每个版本的Android平台都在其内部存储了自己的API级别标识。

应用程序可以用框架API提供的清单文件元素 — <uses-sdk> 来描述该应用程序可以运行的最小和最大API级别,以及应用程序开发者设计期望运行的平台版本。三种属性分别描述如下:

android:minSdkVersion — 指明该应用程序可以运行的API最低版本。默认是“1”。
android:targetSdkVersion — 指明该应用程序设计时期望运行的目标API版本。这允许应用程序使用目标API级别下定义的清单元素或行为,而不是只限于使用最低API级别定义的内容。
android:maxSdkVersion — 指明该应用程序可以运行的最高API级别。

用户尝试安装一个应用程序,或者在系统升级后重验证应用程序的时候,Android系统首先会检查应用程序的清单文件中的<uses-sdk>属性,将其与系统内部API级别对比。系统只有在满足下列情况时才允许进行应用程序安装:

如果声明了android:minSdkVersion属性,其属性值必须小于或等于该系统的API级别对应的整数值。如果未声明,系统会默认该应用程序运行需要的最低API级别是1。
如果声明了android:maxSdkVersion属性,其属性值必须等于或大于该系统的API级对应的整数值。如果未声明,系统会默认该应用程序没有最高API级别限制。

应用程序清单文件中声明该属性后, <uses-sdk>元素看起来应类似于下面的例子:

[[转载]Android <wbr alt=] - API Levels" name=image_operate_69861311043279109 alt="[转载]Android - API Levels" src="http://s14.sinaimg.cn/middle/48a45b95xa8630b496c5d&690" real_src="http://s14.sinaimg.cn/middle/48a45b95xa8630b496c5d&690">

这样做的主要原因是,应用程序会通过android:miniSdkVersion声明的API级别来告知系统——该应用程序使用的API是指定引入的API级别。假如没有这种属性声明,一个应用程序如果因为某些不知名的原因被安装在低级别API系统之上,那么该应用程序会在运行时因为尝试访问不存在的API而崩溃。为此,Android系统通过不允许应用程序被安装在不满足其最低API级别要求的目标硬件上来防止此类结果发生。

例如,android.appwidget类包是在API级别3中开始引入的。如果一个应用程序使用了这个API,就必须通过指明android:minSdkVersion属性为3来声明运行的最低要求。于是,该应用程序就可以在Android 1.5(API级别3级)、Android 1.6 (API级别4级)等平台上安装,但是在Android 1.1 (API级别2级)和 Android 1.0 平台(API级别1级)上却是无法安装的
<template> <view class=""> <z-paging :paging-style="{ background: cardConfig.background }"> <!-- #ifndef H5 --> <view :style="{ height: navBarHeight + 'px' }"></view> <!-- #endif --> <!-- 导航栏 --> <view class="padding flex align-center justify-between"> <view @click="goback()"> <u-icon name="arrow-left"></u-icon> </view> <view class="text-bold text-df">会员中心</view> <view></view> </view> <view class="margin-top-xl"></view> <!-- 轮播图:左右滑动查看不同等级 --> <swiper @change="onSwiperChange" :current="index" :autoplay="false"> <swiper-item v-for="(level, i) in levels" :key="i"> <view class="margin-lr"> <view :class="'member ' + level.class"> <!-- 进度条区域 --> <view class="flex align-end justify-start" style="height: 150px;"> <view class="padding"> <!-- 当前积分 / 所需积分 --> <view class="text-xs padding-top-lg"> 积分:{{ userPoints }} / {{ level.required }} </view> <!-- 进度条 --> <view style="width: 420rpx;"> <u-line-progress active-color="#fff" height="12" :percent="getPercent(i)" :show-percent="false" inactive-color="#D2C1AD" /> </view> <!-- 提示语 --> <view class="text-xs"> 再升一级可享受【优惠券】等12项权益 </view> </view> </view> </view> </view> </swiper-item> </swiper> <!-- 会员权益 --> <view class="w-94 margin-top-lg"> <view class="text-df text-bold margin-bottom-lg">会员权益</view> <view class="text-df" style="color: #86909C;"> 1、如您需要充值余额退款服务,请点击<text class="text-black">申请余额退款</text>。工作人员审核通过后余额将原路退回到您的账户。 </view> <view class="text-df margin-top" style="color: #86909C;"> 2、如您需要充值余额退款服务,请点击<text class="text-black">申请余额退款</text>。工作人员审核通过后余额将原路退回到您的账户。 </view> </view> <!-- 会员礼包 --> <view class="w-94 margin-top-lg"> <view class="text-df text-bold">会员礼包</view> <view class="flex justify-between align-center"> <view class="margin-top coupon-bg flex justify-center align-center" style="height: 164rpx; width: 218rpx; position: relative;" v-for="item in 3" :key="item"> <view> <view class="text-bold" style="font-size: 40rpx; color: #2E1305;">¥42</view> <view class="margin-top-sm" style="color: #2E1305;">会员礼金</view> </view> <view class="title flex align-center justify-center">每月</view> </view> </view> </view> </z-paging> </view> </template> 怎么填充
最新发布
11-18
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值