幾乎每一種版本控制系統(tǒng)都以某種形式支持分支。使用分支意味著可以從開(kāi)發(fā)主線上分離開(kāi)來(lái),然后在不影響主線的同時(shí)繼續(xù)工作。在很多版本控制系統(tǒng)中,這是個(gè)昂貴的過(guò)程,常常需要?jiǎng)?chuàng)建一個(gè)源代碼目錄的完整副本,對(duì)大型項(xiàng)目來(lái)說(shuō)會(huì)花費(fèi)很長(zhǎng)時(shí)間
有人把Git的分支模型稱為“必殺技特性”,而正是因?yàn)樗?,將Git從版本控制系統(tǒng)家族里區(qū)分出來(lái)。Git有何特別之處呢?Git的分支可謂是難以置信的輕量級(jí),它的新建操作幾乎可以在瞬間完成,并且在不同分支間切換起來(lái)也差不多一樣快。和許多其他版本控制系統(tǒng)不同,Git鼓勵(lì)在工作流程中頻繁使用分支與合并,哪怕一天之內(nèi)進(jìn)行許多次都沒(méi)有關(guān)系。理解分支的概念并熟練運(yùn)用后,才會(huì)意識(shí)到為什么Git是一個(gè)如此強(qiáng)大而獨(dú)特的工具,并從此真正改變開(kāi)發(fā)方式。本文將詳細(xì)介紹Git分支
定義
為了理解Git分支的實(shí)現(xiàn)方式,我們需要回顧一下Git是如何儲(chǔ)存數(shù)據(jù)的。Git保存的不是文件差異或者變化量,而只是一系列文件快照
在Git中提交時(shí),會(huì)保存一個(gè)提交(commit)對(duì)象,該對(duì)象包含一個(gè)指向暫存內(nèi)容快照的指針,包含本次提交的作者等相關(guān)附屬信息,包含零個(gè)或多個(gè)指向該提交對(duì)象的父對(duì)象指針:首次提交是沒(méi)有直接祖先的,普通提交有一個(gè)祖先,由兩個(gè)或多個(gè)分支合并產(chǎn)生的提交則有多個(gè)祖先
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動(dòng)安全 [無(wú)線安全]玩轉(zhuǎn)無(wú)線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊(duì)列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識(shí)別反義詞同義詞 2017-07-26
- 從棧不平衡問(wèn)題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實(shí)現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動(dòng)安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來(lái)看看(二) 2017-07-26