都學(xué)到 fetch 和 pull ,想必你已經(jīng)了解了“分支”的概念,很簡單,如果還不了解分支請自行查找學(xué)習(xí)。
GIT FETCH
理解 git fetch 的關(guān)鍵是理解 FETCH_HEAD
FETCH_HEAD ??
解釋:某個(gè)分支(branch)在服務(wù)器上的最新狀態(tài)。
兩種情況
- 如果沒有顯示指定遠(yuǎn)程分支,遠(yuǎn)程分支的 master 將作為默認(rèn)的 FETCH_HEAD
例如:git fetch origin 或 git fetch origin master - 如果已指定遠(yuǎn)程分支,則將這個(gè)遠(yuǎn)程分支作為 FETCH_HEAD
例如:git fetch origin dev 設(shè)定當(dāng)前分支的 FETCH_HEAD 為遠(yuǎn)程服務(wù)器的 dev 分支。它就相當(dāng)于 git pull origin dev 的第一步,并不會(huì)在本地創(chuàng)建新的分支。另外 git fetch origin dev 這個(gè)命令可以用來測試遠(yuǎn)程分支 dev 是否存在。
git fetch origin dev :branch1
上面這個(gè)命令的執(zhí)行過程如下
首先執(zhí)行上面的 fetch 操作
使用遠(yuǎn)程 dev 分支在本地創(chuàng)建 branch1 分支(但不會(huì)切換到該分支)
如果本地不存在 branch1,則會(huì)自動(dòng)創(chuàng)建一個(gè)新的 branch1 分支,如果存在branch1,并且是 fast forward,則會(huì)自動(dòng)合并這2個(gè)分支,否則會(huì)阻止以上的操作