搜尋
首頁php教程PHP开发Git 教學課程分支管理詳解

Git 分支管理

幾乎每一種版本控制系統都以某種形式支援分支。使用分支意味著你可以從開發主線上分離開來,然後在不影響主線的同時繼續工作。

有人把 Git 的分支模型稱為"必殺技特性",而正是因為它,將 Git 從版本控制系統家族中區分出來。

建立分支指令:

git branch (branchname)

切換分支指令:

git checkout (branchname)


git checkout (branchname)


git checkout (branchname)


替換你的工作目錄的內容, 所以多個分支不需要多個目錄。


合併分支指令:


git merge


你可以多次合併到統一分支, 也可以選擇在合併之後直接刪除被併入的分支。


Git 分支管理


列出分支


列出分支基本指令:


git branch

沒有參數時,git branch 會列出你在本地的分支 bgit。

$ git branch
* master


此例的意思就是,我們有一個叫做"master"的分支,並且該分支是當前分支。

當你執行 git init 的時候,缺省情況下 Git 就會為你創建"master"分支。


如果我們要手動建立一個分支,並切換過去。執行 git branch (branchname) 即可。


$ git branch testing
$ git branch
* master
 testing

   


現在我們可以看到,有了一個新分支 testing。

當你以此方式在上次提交更新之後創建了新分支,如果後來又有更新提交, 然後又切換到了"testing"分支,Git 將還原你的工作目錄到你建立分支時候的樣子


接下來我們將示範如何切換分支,我們用 git checkout (branch) 切換到我們要修改的分支。

$ ls
README
$ echo 'w3cschool.cc' > test.txt
$ git add .
$ git commit -m 'add test.txt'
[master 048598f] add test.txt
 2 files changed, 1 insertion(+), 3 deletions(-)
 delete mode 100644 hello.php
 create mode 100644 test.txt
$ ls
README test.txt
$ git checkout testing
Switched to branch 'testing'
$ ls
README hello.php

   

當我們切換到"testing"分支的時候,我們新增的新檔案test.txt被移除了, 原來被刪除的檔案hello.php檔案又出現了。切換回"master"分支的時候,它們有重新出現了。

$ git checkout master
Switched to branch 'master'
$ ls
README test.txt

   



我們也可以使用 git checkout -b (branchname) 指令來建立新分支並立即切換到該分支下,從而在該分支中操作。

$ git checkout -b newtest
Switched to a new branch 'newtest'
$ git rm test2.txt 
rm 'test2.txt'
$ ls
README test.txt
$ git commit -am 'removed test2.txt'
[newtest 556f0a0] removed test2.txt
 1 file changed, 1 deletion(-)
 delete mode 100644 test2.txt
$ git checkout master
Switched to branch 'master'
$ ls
README test.txt test2.txt

   

如你所見,我們創建了一個分支,在該分支的上下文中移除了一些文件,然後切換回我們的主分支,那些文件又回來了。
使用分支將工作切分開來,從而讓我們能夠在不同上下文中做事,並來回切換。


刪除分支


刪除分支指令:

git branch -d (branchname)


了獨立內容,你終究會希望將它合併回到你的主分支。 你可以使用以下指令將任何分支合併到目前分支中去:


git merge


$ git branch
* master
 testing
$ git branch -d testing
Deleted branch testing (was 85fc7e7).
$ git branch
* master

   

以上實例中我們將 newtest 分支合併到主分支去,test2.txt 檔案被刪除。


合併衝突


合併並不僅僅是簡單的文件添加、移除的操作,Git 也會合併修改。


$ git branch
* master
 newtest
$ ls
README test.txt test2.txt
$ git merge newtest
Updating 2e082b7..556f0a0
Fast-forward
 test2.txt | 1 -
 1 file changed, 1 deletion(-)
 delete mode 100644 test2.txt
$ ls
README test.txt

   將修改的內容提交到 "change_site" 分支。 現在,假如切換回 "master" 分支我們可以看內容恢復到我們修改前的,我們再修改test.txt檔案。

$ git branch
* master
$ cat test.txt
w3cschool.cc
首先,我们创建一个叫做"change_site"的分支,切换过去,我们将内容改为 www.w3cschool.cc 。
$ git checkout -b change_site
Switched to a new branch 'change_site'
$ vim test.txt 
$ head -1 test.txt 
www.w3cschool.cc
$ git commit -am 'changed the site'
[change_site d7e7346] changed the site
 1 file changed, 1 insertion(+), 1 deletion(-)

   

現在這些改變已經記錄到我的 "master" 分支了。接下來我們將 "change_site" 分支合併過來。


$ git checkout master
Switched to branch 'master'
$ head -1 test.txt 
w3cschool.cc
$ vim test.txt 
$ cat test.txt
w3cschool.cc
新增加一行
$ git diff
diff --git a/test.txt b/test.txt
index 704cce7..f84c2a4 100644
--- a/test.txt
+++ b/test.txt
@@ -1 +1,2 @@
 w3cschool.cc
+新增加一行
$ git commit -am '新增加一行'
[master 14b4dca] 新增加一行
 1 file changed, 1 insertion(+)

   

我們將前一個分支合併到 "master" 分支,一個合併衝突就出現了,接下來我們需要手動去修改它。


$ git merge change_site
Auto-merging test.txt
CONFLICT (content): Merge conflict in test.txt
Automatic merge failed; fix conflicts and then commit the result.
$ cat test.txt 
<<<<<<< HEAD
w3cschool.cc
新增加一行
=======
www.w3cschool.cc
>>>>>>> change_site

   

在 Git 中,我們可以用 git add 要告訴 Git 文件衝突已經解決


$ vim test.txt 
$ cat test.txt 
www.w3cschool.cc
新增加一行
$ git diff
diff --cc test.txt
index f84c2a4,bccb7c2..0000000
--- a/test.txt
+++ b/test.txt
@@@ -1,2 -1,1 +1,2 @@@
- w3cschool.cc
+ www.w3cschool.cc
 +新增加一行

   

 以上就是Git 教程之分支管理詳解的內容,更多相關文章請關注PHP中文網(www.php.cn)!


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版