教程8--分支
作用
分支在實際中有什么用呢?假設你準備開發(fā)一個新功能,但是需要兩周才能完成,第一周你寫了50%的代碼,如果立刻提交,由于代碼還沒寫完,不完整的代碼庫會導致別人不能干活了。如果等代碼全部寫完再一次提交,又存在丟失每天進度的巨大風險。 現在有了分支,就不用怕了。你創(chuàng)建了一個屬于你自己的分支,別人看不到,還繼續(xù)在原來的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到開發(fā)完畢后,再一次性合并到原來的分支上,這樣,既安全,又不影響別人工作。原理
在版本回退里,你已經知道,每次提交,Git都把它們串成一條時間線,這條時間線就是一個分支。截止到目前,只有一條時間線,在Git里,這個分支叫主分支,即master分支。HEAD嚴格來說不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是當前分支。圖解
一開始的時候,master分支是一條線,Git用master指向最新的提交,再用HEAD指向master,就能確定當前分支,以及當前分支的提交點:
每次提交,master分支都會向前移動一步,這樣,隨著你不斷提交,master分支的線也越來越長:
當我們創(chuàng)建新的分支,例如dev時,Git新建了一個指針叫dev,指向master相同的提交,再把HEAD指向dev,就表示當前分支在dev上:
Git創(chuàng)建一個分支很快,因為除了增加一個dev指針,改改HEAD的指向,工作區(qū)的文件都沒有任何變化!不過,從現在開始,對工作區(qū)的修改和提交就是針對dev分支了,比如新提交一次后,dev指針往前移動一步,而master指針不變:
假如我們在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最簡單的方法,就是直接把master指向dev的當前提交,就完成了合并
所以Git合并分支也很快!就改改指針,工作區(qū)內容也不變!合并完分支后,甚至可以刪除dev分支。刪除dev分支就是把dev指針給刪掉,刪掉后,我們就剩下了一條master分支:
具體操作
1、創(chuàng)建分支
命令:git checkout -b dev2、查看當前分支情況
命令:git branch
上面列出了所有分支,當前分支前面會標一個*號
3、開發(fā)
下面就在dev分支上繼續(xù)開發(fā),比如在某個文件(readme.txt)上作出修改然后,提交
git add readme.txt
git commit -m "分支測試"
4、切換分支
命令: git checkout master切換回master分支后,再查看一個readme.txt文件,剛才添加的內容不見了!因為那個提交是在dev分支上,而master分支此刻的提交點并沒有變:
5、合并分支
注意:必須在需要添加功能的分支,而不是開發(fā)分支。如:我們在dev分支上開發(fā)了新功能,要合并到主分支master,就要在dev上提交后再切換到master,然后在主分支上去合并dev分支;
命令:git merge dev
git merge命令用于合并指定分支到當前分支。合并后,再查看readme.txt的內容,就可以看到,和dev分支的最新提交是完全一樣的。注意到上面的Fast-forward信息,Git告訴我們,這次合并是“快進模式”,也就是直接把master指向dev的當前提交,所以合并速度非常快。當然,也不是每次合并都能Fast-forward,我們后面會講其他方式的合并。合并完成后,就可以放心地刪除dev分支了:
6、刪除分支
命令:git branch -d dev刪除后,查看branch,就只剩下master分支了:7、常用分支命令
查看分支:git branch創(chuàng)建分支:git branch <name>切換分支:git checkout <name>創(chuàng)建+切換分支:git checkout -b <name>合并某分支到當前分支:git merge <name>刪除分支:git branch -d <name>8、分支合并策略
在實際開發(fā)中,我們應該按照幾個基本原則進行分支管理:首先,master分支應該是非常穩(wěn)定的,也就是僅用來發(fā)布新版本,平時不能在上面干活;那在哪干活呢?干活都在dev分支上,也就是說,dev分支是不穩(wěn)定的,到某個時候,比如1.0版本發(fā)布時,再把dev分支合并到master上,在master分支發(fā)布1.0版本;你和你的小伙伴們每個人都在dev分支上干活,每個人都有自己的分支,時不時地往dev分支上合并就可以了。所以,團隊合作的分支看起來就像這樣:轉載于:https://www.cnblogs.com/daxiang2008/p/10727444.html
總結
- 上一篇: 分支结构,循环结构,for循环,九九乘法
- 下一篇: js 正则常用方法