搜尋
首頁開發工具Gitgit中push和pull的差別是什麼

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
GitHub:發現,共享和為代碼做出貢獻GitHub:發現,共享和為代碼做出貢獻May 08, 2025 am 12:26 AM

GitHub是開發者發現、分享和貢獻代碼的首選平台。 1)通過搜索功能查找特定代碼庫,如Python項目。 2)創建倉庫並推送代碼分享給全球開發者。 3)通過Fork和PullRequest參與開源項目並貢獻代碼。

將git與github使用:實用指南將git與github使用:實用指南May 07, 2025 am 12:11 AM

Git是一種版本控制系統,GitHub是基於Git的在線平台。使用Git和GitHub進行代碼管理和團隊協作的步驟包括:1.初始化Git倉庫:gitinit。 2.添加文件到暫存區:gitadd.。 3.提交更改:gitcommit-m"Initialcommit"。 4.關聯GitHub倉庫:gitremoteaddoriginhttps://github.com/username/repository.git。 5.推送代碼到GitHub:gitpush-uoriginmaste

GitHub的影響:軟件開發與協作GitHub的影響:軟件開發與協作May 06, 2025 am 12:09 AM

GitHub對軟件開發和協作的影響深遠:1.它基於Git的分佈式版本控制系統,提高了代碼安全性和開發靈活性;2.通過PullRequest等功能,提升了團隊協作效率和知識共享;3.GitHubActions等工具幫助優化開發流程,提高代碼質量。

使用GitHub:共享,管理和為代碼做出貢獻使用GitHub:共享,管理和為代碼做出貢獻May 05, 2025 am 12:12 AM

在GitHub上分享、管理和貢獻代碼的方法包括:1.創建倉庫並推送代碼,編寫README和LICENSE文件;2.使用分支、標籤和合併請求管理代碼;3.Fork倉庫、修改並提交PullRequest貢獻代碼。通過這些步驟,開發者可以有效利用GitHub提升開發效率和協作能力。

git vs. github:比較分析git vs. github:比較分析May 04, 2025 am 12:07 AM

Git是一個分佈式版本控制系統,GitHub是一個基於Git的協作平台。 Git用於版本控制和代碼管理,GitHub則提供額外的協作功能,如代碼審查和項目管理。

git vs. github:了解差異git vs. github:了解差異May 03, 2025 am 12:08 AM

Git是分佈式版本控制系統,GitHub是基於Git的在線平台。 Git用於版本控制、分支管理和合併,GitHub提供代碼託管、協作工具和社交網絡功能。

github:前端,git:後端github:前端,git:後端May 02, 2025 am 12:16 AM

Git是後端版本控制系統,GitHub是基於Git的前端協作平台。 Git管理代碼版本,GitHub提供用戶界面和協作工具,兩者協同工作提升開發效率。

終極攤牌:git vs. github終極攤牌:git vs. githubMay 01, 2025 am 12:23 AM

Git是版本控制系統,GitHub是基於Git的代碼託管平台。 Git用於管理代碼版本和歷史,GitHub提供代碼託管和協作功能。 Git適用於所有需要版本控制的項目,GitHub適合團隊協作和開源項目。

See all articles

熱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

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

熱工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

PhpStorm Mac 版本

PhpStorm Mac 版本

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

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

記事本++7.3.1

記事本++7.3.1

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