首頁 開發工具 Git git中push和pull的差別是什麼

git中push和pull的差別是什麼

Jan 07, 2022 pm 04:26 PM
git

git中push和pull的區別:1、“git push”命令是將本地庫中的最新信息發送給遠端庫,用於將本地分支的更新,推送到遠端主機;2、“ git pull」指令是從遠端取得最新版本到本機庫,用於從另一個儲存庫或本機分支取得並整合整合。

git中push和pull的差別是什麼

本文操作環境:Windows10系統、Git2.30.0版、Dell G3電腦。

git中push和pull的差別是什麼

#git push與git pull是一對推送/拉取分支的git指令。

git push 使用本地的對應分支來更新對應的遠端分支

$ git push <远程主机名> <本地分支名>:<远程分支名>
登入後複製

注意: 命令中的本地分支是指將要被推送到遠端的分支,而遠端分支是指推送的目標分支,即將本地分支合併到遠端分支。 

如果省略遠端分支名,則表示將本地分支推送與之存在」追蹤關係」的遠端分支(通常兩者同名),如果該遠端分支不存在,則會被新建。

$ git push origin master
登入後複製

上面指令表示,將本地的master分支推送到origin主機的master分支。如果後者不存在,則會被新建。 

origin是一個遠端廠庫位址。

如果省略本機分支名,則表示刪除指定的遠端分支,因為這等同於推送空的本機分支到遠端分支,這條指令是刪除遠端master分支。

$ git push origin :master
# 等同于
$ git push origin --delete master
登入後複製

上面指令表示刪除origin主機的master分支。

如果目前分支與遠端分支之間存在追蹤關係(即分支名稱相同),則本機分支和遠端分支都可以省略。

$ git push origin
登入後複製

上面指令表示,將目前分支推送到origin主機的對應分支。

如果目前分支只有一個追蹤分支,那麼主機名稱都可以省略。

$ git push
登入後複製

如果目前分支與多個主機存在追蹤關係,則可以使用-u選項指定一個預設主機,這樣後面就可以不加任何參數使用git push。

$ git push -u origin master
登入後複製

上面指令將本地的master分支推送到origin主機,同時指定origin為預設主機,後面就可以不加任何參數使用git push了。

不帶任何參數的git push,預設只推送目前分支,這叫做simple方式。此外,還有一種matching方式,會推送所有有對應的遠端分支的本機分支。 Git 2.0版本之前,預設採用matching方法,現在改為預設採用simple方式。如果要修改這個設置,可以採用git config指令。

$ git config --global push.default matching
# 或者
$ git config --global push.default simple
登入後複製

還有一種情況,就是不管是否存在對應的遠端分支,將本地的所有分支都推送到遠端主機,這時需要使用–all選項。

$ git push --all origin
登入後複製

上面指令表示,將所有本機分支都推送到origin主機。

如果遠端主機的版本比本機版本更新,推送時Git會報錯,要求先在本地做git pull合併差異,然後再推送到遠端主機。這時,如果你一定要推送,可以使用–force選項。

$ git push --force origin
登入後複製

上面指令使用–force選項,結果導致在遠端主機產生一個」非直排式」的合併(non-fast-forward merge)。除非你很確定要這樣做,否則應該盡量避免使用–force選項。

最後,git push不會推送標籤(tag),除非使用–tags選項。

$ git push origin --tags
登入後複製

git pull 取得並合併其他的廠庫,或本地的其他分支。

git pull 與 git push操作的目的相同,但是操作的目標相反。指令格式如下:

git pull <远程主机> <远程分支>:<本地分支>
登入後複製

例如:

git pull origin master:my_test
登入後複製

上面的指令是將origin廠庫的master分支拉取並合併到本機的my_test分支上。

如果省略本機分支,則會自動合併到目前所在分支上。如下:

git pull origin master
登入後複製

註:如果你想參與github上的一些優秀的項目,則下面提供一個通用的例子: 

首先,需要一個github的帳號,並fork一個你感興趣的repository。

下面描述過程中會涉及兩個遠程主分支,為了很好的區別,我們把fork出來的主分支稱為遠程A repository,本fork的分支稱為遠程B repository

$git clone <远程Arepository> #克隆你fork出来的分支
$git remote add <远程Brepository标签> git@github.com:XXXX/ceph.git #添加远程Brepository标签
$git pull <远程B厂库标签> master:master  #从远程Brepository的master分支拉取最新objects合并到本地master分支
$git checkout YYYY #切换到要修改的分支上
$git branch develop; git checkout develop #在当前分支的基础上创建一个开发分支,并切换到该分支上,你将在该分支上coding
coding...... #在工作区coding
$git add .#将修改保存到索引区
$git commit -a #将修改提交到本地分区
$git push origin my_test:my_test #将本地分支my_test提交到远程A repository的my_test分支上
登入後複製

接著在github web介面上將my_test分支合併到你需改的遠端B repository 分支上。等待管理員review,如果有問題,就繼續在develop分支當修改,並commit –amend,在之前的commit上修改。知道被meger。

推薦學習:《Git教學

以上是git中push和pull的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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

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

熱工具

記事本++7.3.1

記事本++7.3.1

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

git怎麼更新代碼 git怎麼更新代碼 Apr 17, 2025 pm 04:45 PM

更新 git 代碼的步驟:檢出代碼:git clone https://github.com/username/repo.git獲取最新更改:git fetch合併更改:git merge origin/master推送更改(可選):git push origin master

git怎麼下載項目到本地 git怎麼下載項目到本地 Apr 17, 2025 pm 04:36 PM

要通過 Git 下載項目到本地,請按以下步驟操作:安裝 Git。導航到項目目錄。使用以下命令克隆遠程存儲庫:git clone https://github.com/username/repository-name.git

git commit怎麼用 git commit怎麼用 Apr 17, 2025 pm 03:57 PM

Git Commit 是一種命令,將文件變更記錄到 Git 存儲庫中,以保存項目當前狀態的快照。使用方法如下:添加變更到暫存區域編寫簡潔且信息豐富的提交消息保存並退出提交消息以完成提交可選:為提交添加簽名使用 git log 查看提交內容

git下載不動怎麼辦 git下載不動怎麼辦 Apr 17, 2025 pm 04:54 PM

解決 Git 下載速度慢時可採取以下步驟:檢查網絡連接,嘗試切換連接方式。優化 Git 配置:增加 POST 緩衝區大小(git config --global http.postBuffer 524288000)、降低低速限制(git config --global http.lowSpeedLimit 1000)。使用 Git 代理(如 git-proxy 或 git-lfs-proxy)。嘗試使用不同的 Git 客戶端(如 Sourcetree 或 Github Desktop)。檢查防火

git怎麼合併代碼 git怎麼合併代碼 Apr 17, 2025 pm 04:39 PM

Git 代碼合併過程:拉取最新更改以避免衝突。切換到要合併的分支。發起合併,指定要合併的分支。解決合併衝突(如有)。暫存和提交合併,提供提交消息。

git怎麼更新本地代碼 git怎麼更新本地代碼 Apr 17, 2025 pm 04:48 PM

如何更新本地 Git 代碼?用 git fetch 從遠程倉庫拉取最新更改。用 git merge origin/&lt;遠程分支名稱&gt; 將遠程變更合併到本地分支。解決因合併產生的衝突。用 git commit -m "Merge branch &lt;遠程分支名稱&gt;" 提交合併更改,應用更新。

如何解決PHP項目中的高效搜索問題? Typesense助你實現! 如何解決PHP項目中的高效搜索問題? Typesense助你實現! Apr 17, 2025 pm 08:15 PM

在開發一個電商網站時,我遇到了一個棘手的問題:如何在大量商品數據中實現高效的搜索功能?傳統的數據庫搜索效率低下,用戶體驗不佳。經過一番研究,我發現了Typesense這個搜索引擎,並通過其官方PHP客戶端typesense/typesense-php解決了這個問題,大大提升了搜索性能。

git怎麼刪除倉庫 git怎麼刪除倉庫 Apr 17, 2025 pm 04:03 PM

要刪除 Git 倉庫,請執行以下步驟:確認要刪除的倉庫。本地刪除倉庫:使用 rm -rf 命令刪除其文件夾。遠程刪除倉庫:導航到倉庫設置,找到“刪除倉庫”選項,確認操作。

See all articles