淺談iOS版本號:開發(fā)者對如何更好的用版本號標(biāo)示應(yīng)用
一直在盡量兼容不同使用習(xí)慣的版本號形式, 但是在使用中我們發(fā)現(xiàn)好多開發(fā)者對怎么更好的用版本號來標(biāo)示應(yīng)用很陌生. 這是篇基礎(chǔ)文章, 簡單介紹 iOS 的版本號.
名詞解釋
- Version, 通常說的版本號, 是應(yīng)用向用戶宣傳說明時(shí)候用到的標(biāo)識. 一般有2段或者3段式, 如:
2.1,8.1.2
Version 一般由產(chǎn)品部門確定, 完全迥異的更新需要改變主版本號, 比如 QQ 4.0 的變化非常大, 主版本的變化會(huì)更加吸引用戶的眼球,所以有的應(yīng)用會(huì)頻繁的更新主版本號, 比如 FireFox 20.0 . 兩段式的副版本號既包含小功能更新也會(huì)包含 bug 修復(fù)等,三段式副版本基本都是新功能添加和大問題修復(fù),第三段則表示穩(wěn)定版本基本都是修復(fù) bug
- Build , 編譯號指一次唯一編譯標(biāo)識, 通常是一個(gè)遞增整數(shù)(安卓強(qiáng)制為數(shù)字, iOS 可以是字符串)
Build 都是給內(nèi)部使用, 用來確定一個(gè)唯一版本. 與前面提到的 Version 不會(huì)有太大聯(lián)系.
iOS 開發(fā)中,這個(gè)2個(gè)號碼都可以任意字符串或數(shù)字.
我們目前遇到的情況有:
- 忽略了 Version 或 Build. 這兩個(gè)號中的一個(gè)常年的不會(huì)發(fā)生變化.
- 顛倒了 Version 和 Build.
獲取方法也很簡單:
NSDictionary *info= [[NSBundle mainBundle] infoDictionary];
info[@"CFBundleShortVersionString"]; //Version
info[@"CFBundleVersion"]; // Build
為什么使用版本號
1. 方便標(biāo)示和溝通
前面提到 版本號更新會(huì)給推廣產(chǎn)生一定的積極作用. 所以版本號不要太長, 如果像這樣 "我們隆重推出了 某某某 1.7.14.19257 !", 這個(gè)會(huì)讓用戶感覺很乏味很像電視購物,而且也不利于傳播. 如果是 "某某 3.0, 大有不同 !"可能就會(huì)產(chǎn)生更好的溝通效果.
2. 方便追蹤 Bug
一個(gè)應(yīng)用有 Bug 是肯定的, 但是很快的定位解決問題卻體現(xiàn)出團(tuán)隊(duì)和程序員的能力. 我們經(jīng)常遇到有開發(fā)者說我提交一個(gè)版本, 但是下載下來有還是舊的. 我們幫他解決問題的時(shí)候,他自己都搞不清哪個(gè)是哪個(gè)了, 如果能在"關(guān)于"之類的地方顯示當(dāng)前的版本, 就會(huì)容易找到問題.
或者是測試團(tuán)隊(duì)的同事, 可能手里同時(shí)有幾個(gè)不同分支的版本在測試, 他們需要精確的描述一個(gè)測試版本.
自動(dòng)改變 Build 號
前面提到, Version 是不需要自動(dòng)變化的, 根據(jù)產(chǎn)品或者市場部門的需求,適時(shí)的手動(dòng)改一下就好.
1. agvtool (Apple-generic versioning tool)
agvtool, 是蘋果的命令行工具, 也是集成在 Xcode 中最方便的工具. 我們在自動(dòng)編譯 SDK 的腳本中用的就是這個(gè)方法. 其實(shí)就用了一行(其他的高級用法可以參考前面的鏈接):
agvtool next-version
使用前需要在 Xcode 里簡單配置一下, 如圖:
2. 基于SCM的版本控制號
SCM 現(xiàn)在常用的有 Git 和 SVN, 還有一些相對小眾的比如 hg 這里就不多做介紹了.
如果用 Git/SVN 來管理代碼(詳細(xì)已經(jīng)沒有人不用了) 我們可以用代碼的提交次數(shù)來代替Build號.
- Git
REV=`git rev-list HEAD | wc -l | awk '{print $1}'`
其中 HEAD是分支名, 代表當(dāng)前分支, 可以直接替換成其他分支名, 比如master,dev.
這個(gè)腳本放到
- SVN
REV=`svnversion -nc | sed -e 's/^[^:]*://;s/[A-Za-z]//'`
后面都是一樣的:
PlistBuddy -c "Set :CFBundleShortVersionString ${REV}" "${TARGET_BUILD_DIR}"/${INFOPLIST_PATH}
這樣每次編譯app的時(shí)候就自動(dòng)把版本號加到Info.plist的CFBundleShortVersionString鍵值下
把上面2行代碼 加到 "Build Phase > Run Script"就可以了:
3. 基于日期時(shí)間
用發(fā)布日期作為版本好也是許多應(yīng)用常用的方式, 因?yàn)楹糜浐美斫? 這里直接附上代碼:
REV=`date +%y%m%d` #輸出格式141120的六位日期格式,可以根據(jù)自己喜歡改變格式
后面都是一樣的:
PlistBuddy -c "Set :CFBundleShortVersionString ${REV}" "${TARGET_BUILD_DIR}"/${INFOPLIST_PATH}
使用方法同上.
怎么使用
只要配置好了版本號, 其他的事情就不需要人工干預(yù)了, 這里介紹2種使用場景.
1. Crash 收集
收集 Crash 是應(yīng)用開發(fā)必要的環(huán)節(jié), 通過分析和修復(fù) Crash 信息可以大大提高應(yīng)用的穩(wěn)定性而不會(huì)讓更多的用戶失望甚至刪除應(yīng)用.
目前有很多收集工具, 比如 FIR.im 旗下的BugHD, Crashlytics等.
2. 用戶反饋
能主動(dòng)反饋問題的用戶都是極品用戶, 不管要求是不是合理我們都要認(rèn)真對待.
不管是用各種 SDK 還是用 Email 都要盡量的帶上版本號, 系統(tǒng)信息, 方便確認(rèn)用戶需求.最不濟(jì)也要在"關(guān)于"里面能讓用戶找到相關(guān)的版本信息以便描述問題.


























