git入门-分支
1. git分支簡介
使用分支可以讓你從開發(fā)主線上分離開來,然后在新的分支上解決特定問題,同時不會影響主線。像其它的一些版本控制系統(tǒng),創(chuàng)建分支需要創(chuàng)建整個源代碼目錄的副本。而Git 的分支是很輕量級的,因?yàn)镚it保存的不是文件差異,而是一系列文件快照。在Git提交時,會保存一個commit對象,該對象包含一個指向暫存內(nèi)容快照的指針,Git 會先計算每一個子目錄的校驗(yàn)和( SHA-1 哈希字串),然后在 Git 倉庫中將這些目錄保存為樹(tree)對象。之后 Git 創(chuàng)建的提交對象,除了包含相關(guān)提交信息以外,還包含著指向這個樹對象的指針,如此它就可以在將來需要的時候,重現(xiàn)此次快照的內(nèi)容了。Git 中的分支,其實(shí)本質(zhì)上是個指向 commit 對象的可變指針,Git 會使用 master 作為分支的默認(rèn)名字,
它在每次提交的時候都會自動移動,指向最后一次提交對象。Git使用一個名為HEAD的指針,指向你正在工作的本地分支,這樣你就可以知道當(dāng)前在哪個分支下面工作。
2. 創(chuàng)建分支
| 1 | git branch dev |
上面操作會在當(dāng)前的commit對象上新建一個名為dev的分支指針,但是僅僅是創(chuàng)建了該分支,并沒有切換到dev分支,此時你還在master分支。
3. 切換分支
| 1 | git checkout dev |
此時切換到了新建的dev分支,即HEAD指向了dev分支。
ps:可以加上-b參數(shù)
| 1 | git checkout -b dev |
相當(dāng)于執(zhí)行
| 1 2 | git branch dev git checkout dev |
現(xiàn)在我們在當(dāng)前目錄下進(jìn)行下面的操作:
| 1 2 3 | vim?test.py git add?test.py git commit -m?"add test.py" |
我們在當(dāng)前目錄下新建了test.py文件,并添加到本地倉庫,注意:現(xiàn)在dev分支移動了一格,而master分支還指向原來的commit對象,test.py文件只屬于dev分支,master分支并沒有該文件。
現(xiàn)在切換到master分支
| 1 | git checkout master |
可以看到當(dāng)前目錄下是沒有test.py文件的。因?yàn)镚it 會把工作目錄的內(nèi)容恢復(fù)為檢出某分支時它所指向的那個提交對象的快照,它會自動添加、刪除和修改文件以確保目錄的內(nèi)容和你當(dāng)時提交時完全一樣。
4. 合并分支
使用dev分支完成一些需求后,需要回到開發(fā)主線把它合并到master分支。
| 1 | git merge dev |
ps:需切換到master分支
合并時出現(xiàn)了“Fast-forward”的提示,因?yàn)楫?dāng)前master分支所在的提交對象是要并入的分支dev的直接上游,換句話說,如果順著一個分支直走下去可以到達(dá)另一分支的話,合并兩者時不存在任何需要解決的分歧,只需簡單的移動指針,這種合并過程稱為“Fast-forward”。如果當(dāng)前master分支所指向的提交對象不是dev分支的直接祖先,Git需要做一些額外處理,Git會用兩個分支的末端和它們的共同祖先進(jìn)行一次簡單的三方合并,并做一個新的快照,自動創(chuàng)建一個指向它的提交對象。這個對象有兩個祖先,即之前兩個分支的末端。合并之后,dev分支和master分支指向同一位置,master分支指向的提交對象就是最新的修改了。
如果不同分支修改了同一文件,合并時可能會遇到?jīng)_突,此時Git做了合并,但是并沒有提交。使用git status查看哪些文件發(fā)生了沖突。解決了所有的沖突后,執(zhí)行g(shù)it add將它們添加到暫存區(qū)域,因?yàn)橐坏捍婢捅硎緵_突已解決,然后使用git commit完成這次合并的提交。
5. 刪除分支
| 1 | git branch -d dev |
6. 分支管理
6.1 列出當(dāng)前所有分支的清單
| 1 2 3 4 | git branch dev * master |
master分支前的*字符:表示當(dāng)前所在的分支。
6.2 查看各個分支最后一個提交對象的信息
| 1 2 3 4 | git branch -v dev [7e90b1 add helloworld.java * master c7e90b1 [ahead 1] add helloworld.java |
6.3 查看已經(jīng)與當(dāng)前分支合并的分支
| 1 2 3 4 | git branch --merged dev * master |
6.4 查看已經(jīng)與當(dāng)前分支未合并的分支
| 1 | git branch --no-merged |
7. 遠(yuǎn)程分支
7.1 查看遠(yuǎn)程分支
| 1 2 3 4 | git branch -r origin/HEAD -> origin/master origin/master |
7.2 創(chuàng)建遠(yuǎn)程分支
即把本地分支推送到遠(yuǎn)程
| 1 2 3 4 5 6 | git push origin dev git branch -r origin/HEAD -> origin/master origin/dev origin/master |
看到已把dev分支成功push到服務(wù)器上
7.3 同步遠(yuǎn)程服務(wù)器上的數(shù)據(jù)到本地
| 1 | git fetch origin |
7.4 跟蹤遠(yuǎn)程分支
從遠(yuǎn)程拉取dev分支到本地,并切換到dev分支,ps:需要git1.6.2以上版本
| 1 | git checkout --track origin/dev |
從遠(yuǎn)程拉取dev分支到本地,命名為develop,并切換到develop分支
| 1 | git checkout -b develop origin/dev |
7.5 提交本地分支數(shù)據(jù)到遠(yuǎn)程服務(wù)器
git push origin local:remote
| 1 | git push origin dev:dev |
如果當(dāng)前是在dev分支下工作,可直接git push
7.6 刪除遠(yuǎn)程分支
| 1 | git push origin :dev |
8. 分支的衍合
把一個分支整合到另一個分支有兩種方法:merge和rebase(衍合)
前面已經(jīng)介紹過,merge是把兩個分支最新的快照和二者最新的共同祖先進(jìn)行三方合并,產(chǎn)生一個新的提交對象。rebase是回到兩個分支的共同祖先,根據(jù)要進(jìn)行衍合的分支dev的歷次提交對象,生成一系列文件補(bǔ)丁,然后以主干分支master的最后一個提交對象為新的出發(fā)點(diǎn),逐個應(yīng)用dev分支準(zhǔn)備好的補(bǔ)丁文件,生成一個新的提交對象,改寫dev的提交歷史,使dev成為master的直接下游。然后回到master分支,進(jìn)行一次快進(jìn)合并。這樣能夠保持更加清晰的提交記錄,就像沒有使用過分支一樣。
| 1 2 | git checkout dev git rebase master |
ps:可以把衍合當(dāng)作一種在推送之前清理提交歷史的手段,如果分支中的提交對象已經(jīng)發(fā)布到服務(wù)端,就千萬不要對該分支進(jìn)行衍合。
轉(zhuǎn)載于:https://www.cnblogs.com/wanghuaijun/p/5623023.html
總結(jié)
- 上一篇: 使用ajax进行汽车详情表的查询
- 下一篇: 如何跟下属进行沟通?