iOS 開發(fā)之代碼版本控制:Git

Git 是什么

Git 是一種分布式版本控制系統(tǒng)唐断。每個(gè)團(tuán)隊(duì)成員在本地都有一份整個(gè)代碼倉庫的鏡像盟榴。

為什么用 Git

  • 節(jié)省時(shí)間:Git 命令運(yùn)行快速
  • 離線工作:即使沒有網(wǎng)絡(luò)或是遠(yuǎn)程服務(wù)器宕機(jī)究孕,也可以在本地進(jìn)行幾乎所有的操作
  • 撤銷錯(cuò)誤操作:改正上一個(gè)提交史辙,撤銷一個(gè)完整的提交...
  • 可靠性高:每個(gè)成員都有一個(gè)鏡像份氧,意味著丟失數(shù)據(jù)貨倉庫損壞的概率很低
  • 更高的自由度:強(qiáng)大的分支功能亮航,打造合適的工作流
  • 順應(yīng)潮流:看看有多少知名的開源項(xiàng)目使用 Git 就知道了

Git 基本工作流程

  1. 更改本地倉庫中的某個(gè)文件
  2. 使用 git add 命令將改動(dòng)照添加到暫存區(qū)
  3. 使用 git commit 命令提交改動(dòng)
  4. 使用 git push 命令將改動(dòng)提交到遠(yuǎn)端倉庫

更多的操作參考:

工具和服務(wù)

工作流

基于 Git 強(qiáng)大的分支特性,可以靈活的打造工作流惭载。比如 Atlassian Git TutorialComparing Workflows 章節(jié)中提到的以下四種:

  • Centralized Workflow
  • Feature Branch Workflow
  • Gitflow Workflow
  • Forking Workflow

每一種工作流都有對(duì)應(yīng)適合的使用場景旱函。每個(gè)團(tuán)隊(duì)商定一個(gè)統(tǒng)一的工作流是至關(guān)重要的,可以自己定義一個(gè)完全適合自己項(xiàng)目的工作流描滔,或者使用一個(gè)別人定義好的棒妨。在我以往所待過的團(tuán)隊(duì)中都默認(rèn)使用了一個(gè)當(dāng)前流行的工作流 git-flow

實(shí)際開發(fā)過程中流程可能如下:

  • 初始化得到預(yù)設(shè)的 master 和 develop 分支
  • 從 develop 分支開 feature 分支開發(fā)新功能含长,完成后合并到 develop 分支
  • 功能點(diǎn)都開發(fā)完并經(jīng)過測試后券腔,從 develop 分支上開 release 分支,主要用來做最后的檢查拘泞。等準(zhǔn)備好上架后纷纫,再合并到 master 和 develop,并打上 tag
  • 從 master 分支上打包提交到 App Store
  • 如果發(fā)現(xiàn) master 上的版本有 bug陪腌,從 master 開 hotfix 分支论泛,修復(fù)后再合并到 master 和 develop

SourceTree 也已對(duì)這種工作流提供了支持现恼。

最佳實(shí)踐

  • 正確使用 .gitignore 文件篮奄,避免提交不必要的文件到代碼倉庫兔综,可參考這里燕刻。
  • 提交前充分測試自己的改動(dòng)只泼,這當(dāng)然是最基本的。
  • 每次提交粒度要小卵洗,比如一個(gè)提交只修復(fù)一個(gè)問題请唱,或完成一個(gè)小功能。對(duì)于非常復(fù)雜的新功能过蹂,應(yīng)該將其分割成多個(gè)有意義的邏輯模塊來進(jìn)行提交十绑。精簡的提交可以讓其他的開發(fā)團(tuán)隊(duì)人員更簡單地明白其改動(dòng)的用義。
  • 頻繁地提交改動(dòng)酷勺,便于其他成員共享你的改動(dòng)本橙,減少整合代碼時(shí)的沖突。
  • 提交信息(commit message)規(guī)范化脆诉,加快 code review 進(jìn)度甚亭,便于編寫 release note,便于以后快速回憶起每個(gè)提交的變化击胜。另可參考這里亏狰。
    • 第一行作為標(biāo)題,用少于 50 個(gè)字符來簡短說明偶摔。
    • 在一個(gè)空白分割行后要對(duì)改動(dòng)做一個(gè)詳細(xì)的描述暇唾,比如為什么要進(jìn)行這次修改,具體改動(dòng)了什么。
    • 一定要使用現(xiàn)在時(shí)祈使句策州,動(dòng)詞要用比如 fix瘸味,add,change抽活,而不是 fixed硫戈,added,changed下硕。
  • 靈活使用分支功能丁逝,比如添加新功能,修復(fù)錯(cuò)誤梭姓,嘗試新的想法等等都可以新開一個(gè)分支進(jìn)行霜幼。
  • 遵循一個(gè)工作流程,可根據(jù)項(xiàng)目開發(fā)的類型誉尖,部署模式和團(tuán)隊(duì)成員的個(gè)人習(xí)慣等罪既,商定一個(gè)工作流并一直遵循它。

拓展

  1. Become a git guru.
  2. Learn Version Control with Git
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铡恕,一起剝皮案震驚了整個(gè)濱河市琢感,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌探熔,老刑警劉巖驹针,帶你破解...
    沈念sama閱讀 222,729評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異诀艰,居然都是意外死亡柬甥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門其垄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來苛蒲,“玉大人,你說我怎么就攤上這事绿满”弁猓” “怎么了?”我有些...
    開封第一講書人閱讀 169,461評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵喇颁,是天一觀的道長寄月。 經(jīng)常有香客問我,道長无牵,這世上最難降的妖魔是什么漾肮? 我笑而不...
    開封第一講書人閱讀 60,135評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮茎毁,結(jié)果婚禮上克懊,老公的妹妹穿的比我還像新娘忱辅。我一直安慰自己,他們只是感情好谭溉,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評(píng)論 6 398
  • 文/花漫 我一把揭開白布墙懂。 她就那樣靜靜地躺著,像睡著了一般扮念。 火紅的嫁衣襯著肌膚如雪损搬。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評(píng)論 1 312
  • 那天柜与,我揣著相機(jī)與錄音巧勤,去河邊找鬼。 笑死弄匕,一個(gè)胖子當(dāng)著我的面吹牛颅悉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播迁匠,決...
    沈念sama閱讀 41,179評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼剩瓶,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了城丧?” 一聲冷哼從身側(cè)響起延曙,我...
    開封第一講書人閱讀 40,124評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎亡哄,沒想到半個(gè)月后搂鲫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡磺平,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拐辽。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拣挪。...
    茶點(diǎn)故事閱讀 40,872評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖俱诸,靈堂內(nèi)的尸體忽然破棺而出菠劝,到底是詐尸還是另有隱情,我是刑警寧澤睁搭,帶...
    沈念sama閱讀 36,533評(píng)論 5 351
  • 正文 年R本政府宣布赶诊,位于F島的核電站,受9級(jí)特大地震影響园骆,放射性物質(zhì)發(fā)生泄漏舔痪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評(píng)論 3 336
  • 文/蒙蒙 一锌唾、第九天 我趴在偏房一處隱蔽的房頂上張望锄码。 院中可真熱鬧夺英,春花似錦、人聲如沸滋捶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽重窟。三九已至载萌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間巡扇,已是汗流浹背扭仁。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評(píng)論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留霎迫,地道東北人斋枢。 一個(gè)月前我還...
    沈念sama閱讀 49,304評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像知给,于是被迫代替她去往敵國和親瓤帚。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • 多種多樣的工作流使得在項(xiàng)目中實(shí)施Git時(shí)變得難以選擇涩赢。這份教程提供了一個(gè)出發(fā)點(diǎn)戈次,調(diào)查企業(yè)團(tuán)隊(duì)最常見的Git工作流。...
    JSErik閱讀 4,420評(píng)論 2 8
  • 今天不用接你下班 我慢騰騰的轉(zhuǎn)地鐵 慢騰騰的走回家
    速效救腦丸閱讀 113評(píng)論 0 0
  • 鳥隨鸞鳳飛騰遠(yuǎn)筒扒,人伴賢良品自高怯邪。小時(shí)候,曾經(jīng)是語文老師的奶奶教我背孔子和老子花墩,我一直是有口無心悬秉,于是她讓我去參加廟...
    6897e1c6fd79閱讀 149評(píng)論 0 0
  • 從申請(qǐng)交易離隊(duì)起和泌,歐文就走上一條不歸路。這條路是荊棘祠肥,是坎坷武氓,還是坦途,歐文也不清楚仇箱。他放棄了聯(lián)盟很多人羨慕的機(jī)會(huì)...
    籃球白癡閱讀 369評(píng)論 0 0