小米应用商店运营了大概半年了,过程当中有喜有泪,咱们在运营过程当中,发现有的运营和商务同窗对Android的一些概念了解不深,所以准备了一些知识,会逐步发布出来,第一篇是关于版本的。spa
先上结论:orm
Google为APK定义了两个关于版本属性:VersionCode和VersionName,他们有不一样的用途。开发
VersionCode:对消费者不可见,仅用于应用市场、程序内部识别版本,判断新旧等用途。产品
VersionName:展现给消费者,消费者会经过它认知本身安装的版本,下文提到的版本号都是说VersionName。io
结尾有三个常见问题的解决方案监控
同一个版本号,对应了多个VersionCode怎么办软件
发布了一个VersionCode错误的版本怎么办程序
发出去的应用有Bug要换回旧版,怎么操做?word
而后讲讲来龙去脉计算机
你们在使用软件和应用时,都会涉及到版本的概念,你们都知道的,好比Win XP,QQ2012,小米桌面1.6。之因此会有版本,主要是由于软件产品一直在发展、变化的。版本的概念能够帮助消费者识别不一样时期的产品。
而展示在消费者面前的版本,和开发者内部使用的一般是不一样的版本。开发时一般会使用数字做为标志,好比6.1.7600.16385,实际上是Win 7第一个正式版的版本号,而Win 7 SP1的版本号是6.1.7601.17514,这样长长一串数字对消费者毫无心义,因此在产品发布时一般会起一个更容易懂的版本。下文中会把Win 7这样的用于展现的版本叫作[VersionName],6.1.7601.17514这样用于程序标识的版本叫作[VersionCode]
早年由于软件主要本身负责本身的分发、升级等方面,因此版本号也至关自由,各家都有不一样的规范。可是近年来移动设备崛起,App Store这样的应用商店集中分发成了主流。以升级为例,应用商店会负责检查消费者手机上应用的版本,并和商店里面最新的版本比较,若是商店里面的版本比较新,消费者手机上的版本比较旧,就会提醒消费者升级。
这就涉及到如何识别新、旧的问题。
对于计算机来讲,最可靠的判断方式就是数字,数字有不少好处:程序容易判断、格式简单不容易出错、肉眼容易识别等。因此Google要求每一个应用都要在APK安装包中记录这个安装包的[VersionCode],只要拿到这个APK文件,就能够知道它对应的[VersionCode]是多少,应用商店就会以这个[VersionCode]为准,来判断版本。安装包的[VersionCode]数字越大就越新。这样开发者在开发过程当中,每有一个新版本只要加大一点这个数字就能够了。好比第一个版本的[VersionCode]是1,第二个版本是2。由于开发者可能天天可能会产生多个没有发布的版本,因此这个数字会增加的很快。
通过一段时间的开发,这个数字会变得比较大,好比16385,这时对一个消费者,这样的数字其实不太具备可识别性,好比说Win 16385和Win 17514在传达信息方面效果并很差,不利于产品的市场推广。所以Google也支持在AKP安装包内记录[VersionName],你能够叫Win 七、Win Vista都没问题,能够知足市场、传播方面的需求,这样[VersionName]其实不具有比较新、旧版本的能力,只是用来展现给消费者看的。
综上所述
VersionCode:对消费者不可见,仅用于应用市场、程序内部识别版本,判断新旧等用途。
VersionName:展现给消费者,消费者会经过它认知本身安装的版本。通常咱们说的版本号就是这个。
咱们在运营应用商店的过程当中,发现有的开发者会遇到一些问题。
一、同一个VersionName(版本号),对应了多个VersionCode
这种状况很常见,好比说新版本发布以后,某个商店反馈说存在xxx问题,须要修复、定制等等操做,因而商务找工程师出了个新版本,考虑到是小版本升级,版本号没变化,可是VersionCode已经变了。
可能遇到的问题:若是这个新版只在部分商店上线,就会出现都是3.1版,A商店的版本其实比B商店的新。已经安装了新版本的用户,还会被提示升级,这时候用户会困扰,为何我装了3.1还要升级到3.1?部分商店为了最新会抓包,致使渠道包流窜,影响运营监控和分析。
解决方案:a.版本号应该和VersionCode一块儿涨,并且一旦发布新版本,就在全部渠道上架新版。
二、发布了一个VersionCode错误的版本
有时候由于工程师不当心,发布了一个VersionCode过大的版本,好比1.1.1.20版本的VersionCode写成了111,而1.1.1.27版本的VersionCode写成了11127,可是后面发布1.1.2版但愿延续旧的VersionCode,用112。
可能遇到的问题:1.1.1.27版的用户将没法得到1.1.2版本的升级,由于在程序看来1.1.1.27版本是比较新的,同时,已经使用了1.1.2版本的用户,可能会收到旧版本的升级提示,比并降级回旧版
解决方案:其实很简单,由于VersionCode对最终用户是不可见的,只要增长就行了,上文的例子,新版VersionCode直接取11200就齐活了。
三、发布了一个有Bug的版本,好捉急
偶尔会遇到版本已经发布了,次日忽然发现,糟糕,有Bug,用户开始骂了!因而商务同窗到各家市场要求退回旧版本。