搜尋
首頁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脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具