← 上一章:為什麼要使用分支? 下一章:對分支的誤解 →


開始使用分支

在 Git 使用分支很簡單,只要使用 git branch 指令就行了:

$ git branch
* master

如果 git branch 後面沒接任何參數,它僅會印出目前在這個專案有哪些分支。Git 預設會幫你設定一個名為 master 的分支,前面的星號 * 表示現在正在這個分支上。

在 SourceTree 看的話,會在左邊的選單上看到「BRANCHES」:

branch

目前看到也只有 master 一條分支,在 master 字樣前面的空心小圓圈表示目前正在這個分支上(也就是 HEAD)。

新增分支

要增加一個分支,就是在執行 git branch 指令的時候,在後面加上想要的分支的名字:

$ git branch cat

這樣就新增了一個 cat 分支,再檢視一下:

$ git branch
  cat
* master

的確是有多一個分支,但現分支還是在 master 上。

使用 SourceTree 開分支,只要在上面主選單按下「Branch」按鈕便會跳出對話框:

branch

在這裡填寫想要開的分支的名字,最下方的「Checkout new branch」選項如果打勾的話,就會在建立分支完成之後直接切換到該分支。

分支改名字

如果覺得分支名字取的不夠響亮,想換隨時可以換,而且完全不會影響檔案或目錄。假設現在的分支有這三個:

$ git branch
cat
dog
* master

然後我想把 cat 分支改成 tiger 分支,使用的是 -m 參數:

$ git branch -m cat tiger

看一下目前的分支:

$ git branch
  tiger
  dog
* master

這樣就改掉了。而且即使是 master 分支想改也可以改,例如想把 master 改成 slave

$ git branch -m master slave

看一下目前的分支:

$ git branch
  tiger
  dog
* slave

如果使用 SourceTree 要改分支名字也很簡單,只要在左邊選單的分支上按滑鼠右鍵,選擇「Rename」:

branch

接著輸入想要修改的分支名稱即可。

刪除分支

檢視一下目前的分支:

$ git branch
  cat
  dog
* master

目前共有三個分支,其中如果 dog 分支不想要了,可以使用 -d 參數來刪除它:

$ git branch -d dog
Deleted branch dog (was e12d8ef).

$ git branch
  dog
* master

dog 分支就不見了。但如果要刪的分支還沒被完全合併,Git 會有貼心小提示:

$ git branch -d cat
error: The branch 'cat' is not fully merged.
If you are sure you want to delete it, run 'git branch -D cat'.

的確,因為 cat 的內容還沒被合併,所以使用 -d 參數不給刪。這時只要改用 -D 參數就可以強制刪除:

$ git branch -D cat
Deleted branch cat (was b174a5a).

使用 -D 參數可以強制把還沒合併的分支砍掉,但如果後悔想救回來,請見「【狀況題】不小心把還沒合併的分支砍掉了,救得回來嗎?」章節的說明。

使用 SourceTree 的話,則是在左邊分支的選單上按滑鼠右鍵,選擇「Delete…」功能:

branch

它會出現一個對話框,按下 OK 按鈕就可以把指定的分支刪除:

branch

同樣的,如果該分支還沒被完全合併但仍想強制刪除,則勾選「Force delete」就可順利刪除。

沒有什麼分支是不能刪的!

在 Git 裡什麼分支都可以刪,包括預設的 master 也可以,master 分支只是預設的分支,它並沒有比較特別。真的硬要說哪個分支不能刪的,只有「現在目前所在的分支」不能刪而已(因為刪了的話要去哪裡?),不過只要先切到別的分支就可以刪掉它了。

切換分支

要切換分支,使用的指令在前面「【狀況題】啊!不小心把檔案或目錄刪掉了…」章節也曾經出現過,就是 git checkout

$ git checkout cat
Switched to branch 'cat'

看一下目前的分支狀態:

$ git branch
* cat
  dog
  master

前面的那個星號已經移到 cat 分支上了。

如果是使用 SourceTree,則是在左邊選單的分支名字上按滑鼠右鍵,選擇「Checkout …」

branch

或是直接在分支名字上點兩下也可以切換過去,切換成功的話前面的空心小圈圈(也就是那個 HEAD 啦)就會移到切換的分支上了。

branch

接下來操作就跟一般的差不多,一樣都是先 addcommit,但不一樣的是,當你在 Commit 的時候就只有那個分支會前進喔。

切換分支的時候…

舉個例子來說,我切換到 cat 線,然後在這邊加了兩次 Commit,分別新增一個 cat1.htmlcat2.html

$ git checkout cat
Switched to branch 'cat'

$ touch cat1.html

$ git add cat1.html

$ git commit -m "add cat 1"
[cat c68537b] add cat 1
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 cat1.html

$ touch cat2.html

$ git add cat2.html

$ git commit -m "add cat 2"
[cat b174a5a] add cat 2
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 cat2.html

看一下 Git 紀錄:

$ git log --oneline
b174a5a (HEAD -> cat) add cat 2
c68537b add cat 1
e12d8ef (master, dog) add database.yml in config folder
85e7e30 add hello
657fce7 add container
abb4f43 update index page
cef6e40 create index page
cc797cd init commit

的確比 master 以及 dog 分支多前進了兩次的 Commit。再看一下檔案列表:

$ ls -al
total 16
drwxr-xr-x   9 eddie  wheel   306 Aug 17 18:38 .
drwxrwxrwt  72 root   wheel  2448 Aug 17 18:18 ..
drwxr-xr-x  16 eddie  wheel   544 Aug 17 18:38 .git
-rw-r--r--   1 eddie  wheel     0 Aug 17 18:38 cat1.html
-rw-r--r--   1 eddie  wheel     0 Aug 17 18:38 cat2.html
drwxr-xr-x   3 eddie  wheel   102 Aug 17 15:06 config
-rw-r--r--   1 eddie  wheel     0 Aug 17 15:06 hello.html
-rw-r--r--   1 eddie  wheel   161 Aug 17 18:00 index.html
-rw-r--r--   1 eddie  wheel    11 Aug 17 14:56 welcome.html

在這兩次的 Commit 中,共新增了 cat1.htmlcat2.html 這兩個檔案。這時候,如果切換回原本的 master 分支:

$ git checkout master
Switched to branch 'master'

再看一下檔案列表:

$ ls -al
total 16
drwxr-xr-x   7 eddie  wheel   238 Aug 17 19:10 .
drwxrwxrwt  72 root   wheel  2448 Aug 17 18:18 ..
drwxr-xr-x  16 eddie  wheel   544 Aug 17 19:10 .git
drwxr-xr-x   3 eddie  wheel   102 Aug 17 15:06 config
-rw-r--r--   1 eddie  wheel     0 Aug 17 15:06 hello.html
-rw-r--r--   1 eddie  wheel   161 Aug 17 18:00 index.html
-rw-r--r--   1 eddie  wheel    11 Aug 17 14:56 welcome.html

咦?剛剛那兩個檔案不見了!別擔心,其實他們都還在的,只是在不同的分支而已,只要切回 cat 分支,檔案就會出現了。

要切換到那個分支,首先你要有那個分支…

如果要切換到某個分支,那個分支必要先存在,不然會發生錯誤:

$ git checkout sister
error: pathspec 'sister' did not match any file(s) known to git.

醒醒吧,你沒有這個分支…但沒關係,在 git checkout 分支名稱 的時候加上 -b 參數就沒問題了。如果這個分支本來就存在,那就會直接切換過去;如果不存在,Git 就會幫你建一個,然後再切換過去:

$ git checkout -b sister
Switched to a new branch 'sister'

這樣就搞定了!


← 上一章:為什麼要使用分支? 下一章:對分支的誤解 →

Comments