- 用户需要了解在他们的设备上所安装的应用程序的版本的特定信息, 以及已安装程序的升级版本可用的情况.
- 其他应用程序 - 作为同一个套件中发布的其他应用程序 - 需要从系统中查询你的应用程序的版本号, 来确认兼容性和识别依赖情况.
- 发布应用所依存的服务平台(如Android Market)也可能需要查询你的应用程序的版本号,
然后可以向用户显示版本号.
它们也可能需要通过检查应用的版本号来确认兼容性, 并建立升级/降级的关系.
设置应用程序版本号
2个必须同时定义的属性:
- android:versionCode — 整型,
相对于其他种类的版本号而言, 表示应用程序代码的版本. 其值是个整型,因此其他应用程序可以在程序编码中判断它, 例如检查升级或降级关系. 可以对其设置任何值, 然而应当确保每一个后续发布的应用程序使用更大的值. 尽管系统并不强制执行这种规则, 但是每个后续版本使用增加的数字值是标准作法. 典型做法是, 你发布的第一个版本的versionCode为1, 然后以后的每个发布版本单调递增, 而不管这个发布版本是否是一个主要或者次要的发布版本. 这表示 android:versionCode 值没有必要与用户可见的应用程序发布版本号有特别的相似之处. 同时,应用程序和发布平台不应将此版本值呈现给用户. - android:versionName
---
字符串值,向用户显示的应用程序代码的发布版本号. 此值是一个字符串, 因此可以用<major>.<minor>.<point>的形式描述应用程序版本, 或者以任何其他类型的绝对或相对版本号标识的形式. 相对于 android:versionCode, 除了让应用程序向用户显示它以外, 系统不打算将这个值用于任何内部使用目的. 应用发布平台可能会将 android:versionName 值解析出来显示给用户. 在manifest文件的<manifest>元素中同时定义这些个版本相关属性.
<manifest xmlns:android="http:///apk/res/android" package="com.example.package.name"
android:versionCode="2"
android:versionName="1.1">
<application android:icon="@drawable/icon" android:label="@string/app_name">
...
</application>
</manifest>
try {
PackageInfo info = manager.getPackageInfo(this.getPackageName(), 0);
appVersion = info.versionName; // 版本名,versionCode同理
} catch (NameNotFoundException e) {
e.printStackTrace();
}
指定应用程序的系统API需求
- android:minSdkVersion — 应用程序运行的最小Android平台版本, 由平台的API Level标识指定.
- android:targetSdkVersion — 指定应用设计运行的API
Level.
在一些情况下, 这允许应用程序使用目标API Level中的manifest元素或者行为, 而不是被限制在仅使用最小API Level中的元素. - android:maxSdkVersion - 应用设计运行的Android平台的最大版本, 由平台的API
Level标识指定.
重要: 在使用这个属性之前, 请阅读 <uses-sdk> 文档.
文档信息
















