Git鼓勵大量使用分支:
因為創(chuàng)建、合并和刪除分支非橙幼铮快,所以Git鼓勵你使用分支完成某個任務(wù)桶雀,合并后再刪掉分支矿酵,這和直接在master分支上工作效果是一樣的,但過程更安全全肮。分支用于團隊合作很重要。你在分支上做一些修改辜腺,不會影響主分支的代碼,別人還可以繼續(xù)開發(fā)乍恐。當(dāng)你開發(fā)完成后哪自,則可以將分支合并到主分支上即可。
1禁熏、查看分支:git branch
$ git branch
* dev // dev分支壤巷,當(dāng)前版本庫處于這個分支上瞧毙,前面*號就是處于哪個分支的。
master // 主分支
2宙彪、創(chuàng)建分支:git branch <name>
3、切換分支:git checkout <name>
$ git checkout dev
Switched to branch 'dev' // 選擇跳到dev分支
4悲没、創(chuàng)建+切換分支:git checkout -b <name>
$ git checkout -b dev
Switched to a new branch 'dev' // 選擇跳到一個新的dev分支
他會先創(chuàng)建一個dev分支男图,并跳轉(zhuǎn)過去示姿。
5逊笆、合并某分支到當(dāng)前分支:git merge <name>
$ git merge dev
Updating d17efd8..fec145a // 更新 commit id
Fast-forward // 快進模式
readme.txt | 1 + // readme.txt | 1+ 增加了一行
1 file changed, 1 insertion(+) // 1個文件被改變,插入了一句(+)
6子檀、刪除分支:git branch -d <name>
$ git branch -d dev
Deleted branch dev (was fec145a). // 刪除dev分支(commit id 是fec145a)
7、查看分支合并圖:git log --graph
$ git log --graph --pretty=oneline --abbrev-commit // 查看日志褂痰,以圖形化的形式,一行顯示,縮寫呵燕,提交
* 59bc1cb conflict fixed // commit id 提交的日志
|\
| * 75a857c AND simple //
* | 400b400 & simple //
|/
* fec145a branch test //
8苟翻、 禁用快進模式骗污,合并分支:git merge --no-ff -m "merge with no-ff" dev
$ git merge --no-ff -m "merge with no-ff" dev // 合并,禁止快進模式(no-fast forward)需忿,并提交 “提交日志”
Merge made by the 'recursive' strategy. // 遞歸策略合并
readme.txt | 1 + // readme.txt文件新增了一行 | 1+
1 file changed, 1 insertion(+) // 一個文件被改變,一行插入(+)