查看分支信息
git branch
git branch 命令會(huì)列出所有分支,當(dāng)前分支前面會(huì)標(biāo)一個(gè)*號(hào),效果如下所示:
anyang@anyang:~/anyang/learngit$ git branch
* master
創(chuàng)建分支
git branch <name>
效果如下圖所示:
anyang@anyang:~/anyang/learngit$ git branch test
anyang@anyang:~/anyang/learngit$ git branch
- master
test
git checkout 命令加上 -b 參數(shù)表示創(chuàng)建并切換分支,例如:git checkout -b <name>,效果如下所示:
anyang@anyang:~/anyang/learngit$ git checkout -b test1
Switched to a new branch 'test1'
anyang@anyang:~/anyang/learngit$ git branch
master
test
* test1
切換分支
git checkout <name>
效果如下所示:
anyang@anyang:~/anyang/learngit$ git branch
master
test
* test1
anyang@anyang:~/anyang/learngit$ git checkout test
Switched to branch 'test'
anyang@anyang:~/anyang/learngit$ git branch
master
* test
test1
合并指定分支到當(dāng)前分支
git merge <name>
合并分支時(shí),加上--no-ff 參數(shù)就可以用普通模式進(jìn)行合并,即合并后的歷史能夠看出曾經(jīng)發(fā)生過(guò)合并,默認(rèn)情況下,Git 采用 fast forward 方式進(jìn)行分支合并,即通過(guò)指針移動(dòng)完成的分支合并,因此看不出曾經(jīng)發(fā)生過(guò)合并,效果圖如下所示:
anyang@anyang:~/anyang/learngit$ git branch
master
* test
test1
anyang@anyang:~/anyang/learngit$ vim README.md
anyang@anyang:~/anyang/learngit$ cat README.md
Hello, world!
I am test.
anyang@anyang:~/anyang/learngit$ git add README.md
anyang@anyang:~/anyang/learngit$ git commit -m "Add I am test"
[test 026803a] Add I am test
1 file changed, 1 insertion(+)
anyang@anyang:~/anyang/learngit$ git checkout master
Switched to branch 'master'
anyang@anyang:~/anyang/learngit$ git branch
刪除指定分支
git branch -d <name>
如果要?jiǎng)h除一個(gè)沒(méi)有被合并過(guò)的分支,可以通過(guò)git branch -D <name>強(qiáng)行刪除,效果圖如下所示:
anyang@anyang:~/anyang/learngit$ git branch
* master
test
test1
anyang@anyang:~/anyang/learngit$ git branch -d test
Deleted branch test (was 026803a).
anyang@anyang:~/anyang/learngit$ git branch
* master
test1
anyang@anyang:~/anyang/learngit$ git checkout test1
Switched to branch 'test1'
anyang@anyang:~/anyang/learngit$ vim README.md
anyang@anyang:~/anyang/learngit$ cat README.md
Hello, world!
I am test1.
anyang@anyang:~/anyang/learngit$ git add README.md
anyang@anyang:~/anyang/learngit$ git commit -m "Add I am test1"
[test1 2cc6751] Add I am test1
1 file changed, 1 insertion(+)
anyang@anyang:~/anyang/learngit$ git checkout master
Switched to branch 'master'
anyang@anyang:~/anyang/learngit$ git branch -d test1
error: The branch 'test1' is not fully merged.
If you are sure you want to delete it, run 'git branch -D test1'.
anyang@anyang:~/anyang/learngit$ git branch -D test1
Deleted branch test1 (was 2cc6751).
anyang@anyang:~/anyang/learngit$ git branch
* master
查看分支合并圖
git log --graph --pretty=oneline --abbrev-commit
假設(shè)我們新建分支 branch1,并添加“Hello, branch1.”到 README.md 文件,緊接著切換到 master 分支,添加“Hello, master.”到 README.md 文件,然后合并 branch1 分支到 master 分支,發(fā)生了沖突,通過(guò)查看沖突文件 README.md,修改 master 分支的文件和 branch1 分支相同,再重新合并即可,效果如下圖所示:
anyang@anyang:~/anyang/learngit$ git branch
* master
anyang@anyang:~/anyang/learngit$ cat README.md
Hello, world!
anyang@anyang:~/anyang/learngit$ git checkout -b branch1
M README.md
Switched to a new branch 'branch1'
anyang@anyang:~/anyang/learngit$ vim README.md
anyang@anyang:~/anyang/learngit$ git add README.md
anyang@anyang:~/anyang/learngit$ git commit -m "Add Hello, branch1"
[branch1 e9d1cb7] Add Hello, branch1
1 file changed, 1 insertion(+), 1 deletion(-)
anyang@anyang:~/anyang/learngit$ cat README.md
Hello, world!
Hello, branch1.
anyang@anyang:~/anyang/learngit$ git checkout master
Switched to branch 'master'
anyang@anyang:~/anyang/learngit$ vim README.md
anyang@anyang:~/anyang/learngit$ cat README.md
Hello, world!
Hello, master.
anyang@anyang:~/anyang/learngit$ git add README.md
anyang@anyang:~/anyang/learngit$ git commit -m "Add Hello, master"
[master 16a1460] Add Hello, master
1 file changed, 1 insertion(+), 1 deletion(-)
anyang@anyang:~/anyang/learngit$ git merge branch1
Auto-merging README.md
CONFLICT (content): Merge conflict in README.md
Automatic merge failed; fix conflicts and then commit the result.
anyang@anyang:~/anyang/learngit$ git status
On branch master
You have unmerged paths.
(fix conflicts and run "git commit")
(use "git merge --abort" to abort the merge)
Unmerged paths:
(use "git add <file>..." to mark resolution)
both modified: README.md
no changes added to commit (use "git add" and/or "git commit -a")
anyang@anyang:~/anyang/learngit$ vim README.md
snapshot.png
anyang@anyang:~/anyang/learngit$ vim README.md
anyang@anyang:~/anyang/learngit$ cat README.md
Hello, world!
Hello, branch1.
anyang@anyang:~/anyang/learngit$ git add README.md
anyang@anyang:~/anyang/learngit$ git commit -m "conflict fixed"
[master 44d9f6f] conflict fixed
anyang@anyang:~/anyang/learngit$ git merge branch1
Already up-to-date.
anyang@anyang:~/anyang/learngit$ git log --graph --pretty=oneline --abbrev-> > commit
* 44d9f6f conflict fixed
|\
| * e9d1cb7 Add Hello, branch1
* | 16a1460 Add Hello, master
|/
* 026803a Add I am test
* 513dec6 Add Hello, world!
* 72f8209 Add README.md
相關(guān)資料:
- Git 官網(wǎng)
- Git 官方文檔
- [廖雪峰的 Git 教程](http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8
067c8c017b000) - Git 常用命令查詢(xún)文檔
- Git 在線學(xué)習(xí)網(wǎng)址
