日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

Git初学札记(六)————在远程新建本地Branch与在本地新建远程Branch

發(fā)布時(shí)間:2025/3/12 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Git初学札记(六)————在远程新建本地Branch与在本地新建远程Branch 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

引言

本篇博客介紹將現(xiàn)有的本地分支以新的分支形式推送到遠(yuǎn)程庫(kù)中,和以新的分支的形式從遠(yuǎn)程庫(kù)中拉取一個(gè)分支。這兩個(gè)功能都是比較簡(jiǎn)單的操作,但是在實(shí)際開發(fā)中,可能會(huì)在開發(fā)初期有所觸及。比如我們希望將遠(yuǎn)程的dev分支拉取到本地來進(jìn)行開發(fā),或者將本地的dev分支推到遠(yuǎn)程庫(kù)中去等等。

推送本地分支

在EGit中,我們切換到一個(gè)已存在的分支,或者新建一個(gè)新的分支:

右鍵項(xiàng)目 ,Team>Switch To>New Branch



此時(shí),我們已經(jīng)切換到了新建的這個(gè)"feature_push_new_branch"分支上

再次右鍵項(xiàng)目>Team>Push Branch '當(dāng)前分支名稱'...



這里由于項(xiàng)目已經(jīng)關(guān)聯(lián)了一個(gè)遠(yuǎn)程庫(kù),因此Destination選項(xiàng)欄中的信息已經(jīng)自動(dòng)創(chuàng)建完畢,而Branch輸入框就代表在遠(yuǎn)程庫(kù)上顯示的分支名稱,這里為了區(qū)分顯示,我特意手動(dòng)修改了一下遠(yuǎn)程庫(kù)中分支的名稱(加了一個(gè)“GitHub”),點(diǎn)擊Preview。


在push確認(rèn)信息提示框內(nèi),我們可以確認(rèn)我們的push分支信息,可以看到[new branch]的標(biāo)識(shí),代表是新的分支。點(diǎn)擊Push。等待片刻后,就會(huì)收到一個(gè)提示信息。


最后,檢查一下遠(yuǎn)程庫(kù)中的分支是否多了一個(gè)名為“feature_push_new_branch_GitHub”新分支。


完美!????乛?乛????

拉取遠(yuǎn)程分支

有推送就有拉取。我們假設(shè)已經(jīng)在遠(yuǎn)程庫(kù)存在了dev分支(在上圖中我們也可以看到),這個(gè)時(shí)候我們檢查一下本地是否有dev分支:

刪除本地分支

在Git Repositories視圖中我們可以看到本地全部的倉(cāng)庫(kù)信息,找到對(duì)應(yīng)的倉(cāng)庫(kù),Branches>Local


如圖可以很清晰的看到,我們的當(dāng)前分支時(shí)feature_push_new_branch上,且已經(jīng)存在了dev分支(實(shí)際上我就是用dev分支練習(xí)了將分支push到遠(yuǎn)程新分支的功能),接下來,我們先刪除這個(gè)dev分支,然后我們?cè)賴L試從GitHub上取下dev分支。

右鍵需要?jiǎng)h除的分支>Delete Branch ,注意當(dāng)前分支是無法刪除的,如果想刪除當(dāng)前分支,請(qǐng)先切換到其他分支上去。


刪除結(jié)果如下:


可以看到dev分支已經(jīng)被刪除了。另外需要說明一下,如果被刪除的分支有一些還沒有來得及合并的修改,那么在刪除的時(shí)候會(huì)彈出提示信息,讓你再一次確認(rèn)要?jiǎng)h除的分支。

修改checked-out遠(yuǎn)程分支?!

還是在Git Repositories視圖中,我們看到Remote Tracking中有一個(gè)名叫origin的遠(yuǎn)程庫(kù)(不用懷疑,就是GitHub上對(duì)應(yīng)的項(xiàng)目),它的下面有一個(gè)dev分支(如果沒有,請(qǐng)嘗試F5刷新一下Remote Tracking文件夾)


這里顯示的dev分支的縮略信息未必是實(shí)時(shí)的,我嘗試在遠(yuǎn)程dev分支上添加了一個(gè)readme文件,但是在此處刷新是無法顯示這個(gè)最新操作的,但是通過checkout(分支上右鍵>Check Out)依然可以拿到最新的提交信息。如下圖checkout的結(jié)果:


請(qǐng)注意,可以看到我們的當(dāng)前分支已經(jīng)從之前的feature_push_new_branch切換到了遠(yuǎn)程庫(kù)的dev分支上。

但是如果此刻你直接修改checkout出的代碼,是無法被本地Git倉(cāng)庫(kù)追蹤到的,因?yàn)楸镜夭]有對(duì)應(yīng)的分支來追蹤這些修改,而且遠(yuǎn)程庫(kù)也不會(huì)記錄你此刻的任何修改,即此刻的操作是無用的。

這點(diǎn)千萬要注意,建議小伙伴嘗試一下直接修改checkout出的遠(yuǎn)程分支,看看如果切換回了master分支上,還能不能再重新找回剛才在checkout出的遠(yuǎn)程分支dev上的任何修改,或者看看遠(yuǎn)程庫(kù)上有沒有任何變化被記錄。

因此,如果希望修改遠(yuǎn)程的分支,必須修改本地分支然后再push,不可以直接修改checkout出的遠(yuǎn)程分支。

但是如果你忘記了這點(diǎn),依然在checkout出的遠(yuǎn)程分支上做了一些修改并且已經(jīng)commit了,你切換到了master分支上準(zhǔn)備合并這些修改,突然,你發(fā)現(xiàn)找不到了這些修改怎么辦?不知道小伙伴們是否還記得 git reflog指令?沒錯(cuò),reflog會(huì)記錄下你的每次提交,所以,你可以去查看一下Git Reflog歷史記錄:

必須在Git Repositories視圖,右鍵項(xiàng)目 > Show In > Git Reflog


找到你剛剛做的修改的commit,右鍵 > Checkout ,即檢出了剛才的馬虎修改:


拉取遠(yuǎn)程分支

那么如何將遠(yuǎn)程的分支拉取到本地的一個(gè)新的分支上呢?

右鍵遠(yuǎn)程分支 > Create Branch...


完成新建分支向?qū)?#xff1a;


點(diǎn)擊Finish 結(jié)果如下:


可以看到,我們已經(jīng)將遠(yuǎn)程的dev分支下載(拉取)到了本地,且已經(jīng)checkout,目前的工作區(qū)就是這個(gè)剛剛新建的與遠(yuǎn)程dev分支相關(guān)聯(lián)的分支了,可以放心大膽的在這個(gè)分支上修改提交,Git倉(cāng)庫(kù)會(huì)一如既往地幫助我們跟蹤它的變化。


總結(jié)

本章介紹了如何將新分支push到遠(yuǎn)程庫(kù),以及拉取遠(yuǎn)程的分支(或者可以稱為在本地建立一個(gè)與遠(yuǎn)程某個(gè)分支相關(guān)聯(lián)的新分支)。

另外還包括了一些其他的小操作,如:刪除本地分支,修改了剛剛checkout的遠(yuǎn)程分支的解決辦法。

其實(shí)對(duì)于普通開發(fā)者而言,拉取遠(yuǎn)程分支的操作可能會(huì)用得多一些,推送新分支到遠(yuǎn)程這個(gè)操作可能會(huì)影響服務(wù)器Git管理的混亂,因此一般都是由項(xiàng)目組長(zhǎng)將新的分支push到遠(yuǎn)程去。

文章描述的過程盡可能詳盡,配圖盡可能詳盡,并不是言簡(jiǎn)意賅的類型。

喜歡的朋友可以點(diǎn)贊分享,如有疑問,歡迎文末留言。

參考與感謝

《EGit/User Guide》

總結(jié)

以上是生活随笔為你收集整理的Git初学札记(六)————在远程新建本地Branch与在本地新建远程Branch的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。