吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

SVN與Git的最主要的區別

技術讓夢想更偉大 ? 來源:全棧開發者社區 ? 作者:全棧開發者社區 ? 2022-11-01 10:25 ? 次閱讀

一:Git是什么?



Git是目前世界上最先進的分布式版本控制系統工作原理 / 流程: 1a2f541e-593d-11ed-a3b6-dac502259ad0.jpg

Workspace:工作區

Index / Stage:暫存區

Repository:倉庫區(或本地倉庫)

Remote:遠程倉庫

二:SVN與Git的最主要的區別?

SVN是集中式版本控制系統,版本庫是集中放在中央服務器的,而干活的時候,用的都是自己的電腦,所以首先要從中央服務器哪里得到最新的版本,然后干活,干完后,需要把自己做完的活推送到中央服務器。集中式版本控制系統是必須聯網才能工作,如果在局域網還可以,帶寬夠大,速度夠快,如果在互聯網下,如果網速慢的話,就納悶了。 Git是分布式版本控制系統,那么它就沒有中央服務器的,每個人的電腦就是一個完整的版本庫,這樣,工作的時候就不需要聯網了,因為版本都是在自己的電腦上。既然每個人的電腦都有一個完整的版本庫,那多個人如何協作呢?比如說自己在電腦上改了文件A,其他人也在電腦上改了文件A,這時,你們兩之間只需把各自的修改推送給對方,就可以互相看到對方的修改了。

三、在windows上如何安裝Git?

msysgit是 windows版的Git,如下: 1a438574-593d-11ed-a3b6-dac502259ad0.jpg ? 需要從網上下載一個,然后進行默認安裝即可。安裝完成后,在開始菜單里面找到 "Git --> Git Bash",如下: 1a4a23c0-593d-11ed-a3b6-dac502259ad0.jpg ? 會彈出一個類似的命令窗口的東西,就說明Git安裝成功。如下: ? 1a78f560-593d-11ed-a3b6-dac502259ad0.jpg ? 安裝完成后,還需要最后一步設置,在命令行輸入如下: ? 1a845da6-593d-11ed-a3b6-dac502259ad0.jpg ? 因為Git是分布式版本控制系統,所以需要填寫用戶名和郵箱作為一個標識。 ? 注意:git config --global 參數,有了這個參數,表示你這臺機器上所有的Git倉庫都會使用這個配置,當然你也可以對某個倉庫指定的不同的用戶名和郵箱。 ? 四:如何操作? 一:創建版本庫。 什么是版本庫?版本庫又名倉庫,英文名repository,你可以簡單的理解一個目錄,這個目錄里面的所有文件都可以被Git管理起來,每個文件的修改,刪除,Git都能跟蹤,以便任何時刻都可以追蹤歷史,或者在將來某個時刻還可以將文件”還原”。 所以創建一個版本庫也非常簡單,如下我是D盤 –> www下 目錄下新建一個testgit版本庫。 1a91581c-593d-11ed-a3b6-dac502259ad0.jpg ? pwd 命令是用于顯示當前的目錄。 ? 通過命令 git init 把這個目錄變成git可以管理的倉庫,如下: ? 1a9ce3b2-593d-11ed-a3b6-dac502259ad0.jpg ? 這時候你當前testgit目錄下會多了一個.git的目錄,這個目錄是Git來跟蹤管理版本的,沒事千萬不要手動亂改這個目錄里面的文件,否則,會把git倉庫給破壞了。如下: ? 1aa9af48-593d-11ed-a3b6-dac502259ad0.jpg ? 下面先看下demo如下演示: ? 我在版本庫testgit目錄下新建一個記事本文件 readme.txt 內容如下:11111111 ? 第一步:使用命令 git add readme.txt添加到暫存區里面去。如下: ? 1ac14c8e-593d-11ed-a3b6-dac502259ad0.jpg ? 如果和上面一樣,沒有任何提示,說明已經添加成功了。 ? 第二步:用命令 git commit告訴Git,把文件提交到倉庫。 ? 1ace913c-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我們已經提交了一個readme.txt文件了,我們下面可以通過命令git status來查看是否還有文件未提交,如下: ? 1ad80ee2-593d-11ed-a3b6-dac502259ad0.jpg ? 說明沒有任何文件未提交,但是我現在繼續來改下readme.txt內容,比如我在下面添加一行2222222222內容,繼續使用git status來查看下結果,如下: ? 1ae4a558-593d-11ed-a3b6-dac502259ad0.jpg ? 上面的命令告訴我們 readme.txt文件已被修改,但是未被提交的修改。 ? 把文件添加到版本庫中。 ? 首先要明確下,所有的版本控制系統,只能跟蹤文本文件的改動,比如txt文件,網頁,所有程序的代碼等,Git也不列外,版本控制系統可以告訴你每次的改動,但是圖片,視頻這些二進制文件,雖能也能由版本控制系統管理,但沒法跟蹤文件的變化,只能把二進制文件每次改動串起來,也就是知道圖片從1kb變成2kb,但是到底改了啥,版本控制也不知道。 ? 接下來我想看下readme.txt文件到底改了什么內容,如何查看呢?可以使用如下命令: ? git diff readme.txt 如下: ? 1aef3338-593d-11ed-a3b6-dac502259ad0.jpg ? 如上可以看到,readme.txt文件內容從一行11111111改成 二行 添加了一行22222222內容。 ? 知道了對readme.txt文件做了什么修改后,我們可以放心的提交到倉庫了,提交修改和提交文件是一樣的2步(第一步是git add 第二步是:git commit)。 ? 如下: ? 1afd8fbe-593d-11ed-a3b6-dac502259ad0.jpg ? 二:版本回退: 如上,我們已經學會了修改文件,現在我繼續對readme.txt文件進行修改,再增加一行 內容為33333333333333.繼續執行命令如下: 1b18ba28-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我已經對readme.txt文件做了三次修改了,那么我現在想查看下歷史記錄,如何查呢?我們現在可以使用命令 git log 演示如下所示: ? 1b284376-593d-11ed-a3b6-dac502259ad0.jpg ? git log命令顯示從最近到最遠的顯示日志,我們可以看到最近三次提交,最近的一次是,增加內容為333333.上一次是添加內容222222,第一次默認是 111111.如果嫌上面顯示的信息太多的話,我們可以使用命令?git log –pretty=oneline?演示如下: ? 1b413a2a-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我想使用版本回退操作,我想把當前的版本回退到上一個版本,要使用什么命令呢?可以使用如下2種命令,第一種是:git reset --hard HEAD^?那么如果要回退到上上個版本只需把HEAD^?改成?HEAD^^?以此類推。那如果要回退到前100個版本的話,使用上面的方法肯定不方便,我們可以使用下面的簡便命令操作:git reset --hard HEAD~100?即可。未回退之前的readme.txt內容如下: ? 1b4f4192-593d-11ed-a3b6-dac502259ad0.jpg ? 如果想回退到上一個版本的命令如下操作: ? 1b6024c6-593d-11ed-a3b6-dac502259ad0.jpg ? 再來查看下 readme.txt內容如下:通過命令cat readme.txt查看 ? 1b6aaa04-593d-11ed-a3b6-dac502259ad0.jpg ? 可以看到,內容已經回退到上一個版本了。我們可以繼續使用git log 來查看下歷史記錄信息,如下: ? 1b76049e-593d-11ed-a3b6-dac502259ad0.jpg ? 我們看到 增加333333 內容我們沒有看到了,但是現在我想回退到最新的版本,如:有333333的內容要如何恢復呢?我們可以通過版本號回退,使用命令方法如下: ? git reset --hard?版本號 ,但是現在的問題假如我已經關掉過一次命令行或者333內容的版本號我并不知道呢?要如何知道增加3333內容的版本號呢?可以通過如下命令即可獲取到版本號:git reflog?演示如下: ? 1b826f7c-593d-11ed-a3b6-dac502259ad0.jpg ? 通過上面的顯示我們可以知道,增加內容3333的版本號是 6fcfc89.我們現在可以命令 ? git reset --hard 6fcfc89來恢復了。演示如下: ? 1b8fbe7a-593d-11ed-a3b6-dac502259ad0.jpg ? 可以看到 目前已經是最新的版本了。 ? 三:理解工作區與暫存區的區別?

工作區:就是你在電腦上看到的目錄,比如目錄下testgit里的文件(.git隱藏目錄版本庫除外)。或者以后需要再新建的目錄文件等等都屬于工作區范疇。

版本庫(Repository):工作區有一個隱藏目錄.git,這個不屬于工作區,這是版本庫。其中版本庫里面存了很多東西,其中最重要的就是stage(暫存區),還有Git為我們自動創建了第一個分支master,以及指向master的一個指針HEAD。

我們前面說過使用Git提交文件到版本庫有兩步:

是使用 git add 把文件添加進去,實際上就是把文件添加到暫存區。

使用git commit提交更改,實際上就是把暫存區的所有內容提交到當前分支上。

我們繼續使用demo來演示下: 我們在readme.txt再添加一行內容為4444444,接著在目錄下新建一個文件為test.txt 內容為test,我們先用命令git status來查看下狀態,如下: 1b9e3f54-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我們先使用git add 命令把2個文件都添加到暫存區中,再使用git status來查看下狀態,如下: ? 1bd64d0e-593d-11ed-a3b6-dac502259ad0.jpg ? 接著我們可以使用git commit一次性提交到分支上,如下: ? 1be510b4-593d-11ed-a3b6-dac502259ad0.jpg ? 四:Git撤銷修改和刪除文件操作 一:撤銷修改: 比如我現在在readme.txt文件里面增加一行 內容為555555555555,我們先通過命令查看如下: 1bf51360-593d-11ed-a3b6-dac502259ad0.jpg ? 在我未提交之前,我發現添加5555555555555內容有誤,所以我得馬上恢復以前的版本,現在我可以有如下幾種方法可以做修改: ?

如果我知道要刪掉那些內容的話,直接手動更改去掉那些需要的文件,然后add添加到暫存區,最后commit掉。

我可以按以前的方法直接恢復到上一個版本。使用git reset --hard HEAD^

但是現在我不想使用上面的2種方法,我想直接想使用撤銷命令該如何操作呢?首先在做撤銷之前,我們可以先用git status查看下當前的狀態。如下所示: 1c01e18a-593d-11ed-a3b6-dac502259ad0.jpg ? 可以發現,Git會告訴你,git checkout -- file?可以丟棄工作區的修改,如下命令: ? git checkout -- readme.txt,如下所示: ? 1c113de2-593d-11ed-a3b6-dac502259ad0.jpg ? 命令?git checkout --readme.txt?意思就是,把readme.txt文件在工作區做的修改全部撤銷,這里有2種情況,如下: ?

readme.txt自動修改后,還沒有放到暫存區,使用 撤銷修改就回到和版本庫一模一樣的狀態。

另外一種是readme.txt已經放入暫存區了,接著又作了修改,撤銷修改就回到添加暫存區后的狀態

對于第二種情況,我想我們繼續做demo來看下,假如現在我對readme.txt添加一行 內容為6666666666666,我git add 增加到暫存區后,接著添加內容7777777,我想通過撤銷命令讓其回到暫存區后的狀態。如下所示: 1c21660e-593d-11ed-a3b6-dac502259ad0.jpg ? 注意:命令git checkout -- readme.txt?中的 -- 很重要,如果沒有 -- 的話,那么命令變成創建分支了。 ? 二:刪除文件 假如我現在版本庫testgit目錄添加一個文件b.txt,然后提交。如下: 1c3336fe-593d-11ed-a3b6-dac502259ad0.jpg ? 如上:一般情況下,可以直接在文件目錄中把文件刪了,或者使用如上rm命令:rm b.txt ,如果我想徹底從版本庫中刪掉了此文件的話,可以再執行commit命令 提交掉,現在目錄是這樣的, ? 1c4e58c6-593d-11ed-a3b6-dac502259ad0.jpg ? 只要沒有commit之前,如果我想在版本庫中恢復此文件如何操作呢? ? 可以使用如下命令?git checkout -- b.txt,如下所示: ? 1c5b4f90-593d-11ed-a3b6-dac502259ad0.jpg ? 再來看看我們testgit目錄,添加了3個文件了。如下所示: ? 1c6c6a96-593d-11ed-a3b6-dac502259ad0.jpg ? 五:遠程倉庫 在了解之前,先注冊github賬號,由于你的本地Git倉庫和github倉庫之間的傳輸是通過SSH加密的,所以需要一點設置: 第一步:創建SSH Key。在用戶主目錄下,看看有沒有.ssh目錄,如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個文件,如果有的話,直接跳過此如下命令,如果沒有的話,打開命令行,輸入如下命令: ssh-keygen -t rsa –C “youremail@example.com”, 由于我本地此前運行過一次,所以本地有,如下所示: 1c7c7058-593d-11ed-a3b6-dac502259ad0.jpg ? id_rsa是私鑰,不能泄露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。 ? 第二步:登錄github,打開” settings”中的SSH Keys頁面,然后點擊“Add SSH Key”,填上任意title,在Key文本框里黏貼id_rsa.pub文件的內容。 ? 1c8b3728-593d-11ed-a3b6-dac502259ad0.jpg ? 點擊 Add Key,你就應該可以看到已經添加的key。 ? 1ca9f8e8-593d-11ed-a3b6-dac502259ad0.jpg ? 如何添加遠程庫 現在的情景是:我們已經在本地創建了一個Git倉庫后,又想在github創建一個Git倉庫,并且希望這兩個倉庫進行遠程同步,這樣github的倉庫可以作為備份,又可以其他人通過該倉庫來協作。 首先,登錄github上,然后在右上角找到“create a new repo”創建一個新的倉庫。如下: 1cb9a298-593d-11ed-a3b6-dac502259ad0.jpg ? 在Repository name填入testgit,其他保持默認設置,點擊“Create repository”按鈕,就成功地創建了一個新的Git倉庫: ? 1cd452dc-593d-11ed-a3b6-dac502259ad0.jpg ? 目前,在GitHub上的這個testgit倉庫還是空的,GitHub告訴我們,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然后,把本地倉庫的內容推送到GitHub倉庫。 ? 現在,我們根據GitHub的提示,在本地的testgit倉庫下運行命令: ?


git remote add origin https://github.com/tugenhua0707/testgit.git   所有的如下:  1ce6ccb4-593d-11ed-a3b6-dac502259ad0.jpg ? 把本地庫的內容推送到遠程,使用 git push命令,實際上是把當前分支master推送到遠程。 ? 由于遠程庫是空的,我們第一次推送master分支時,加上了 –u參數,Git不但會把本地的master分支內容推送的遠程新的master分支,還會把本地的master分支和遠程的master分支關聯起來,在以后的推送或者拉取時就可以簡化命令。推送成功后,可以立刻在github頁面中看到遠程庫的內容已經和本地一模一樣了,上面的要輸入github的用戶名和密碼如下所示: ? 1cf4eae2-593d-11ed-a3b6-dac502259ad0.jpg ? 從現在起,只要本地作了提交,就可以通過如下命令: ?

git push origin master   把本地master分支的最新修改推送到github上了,現在你就擁有了真正的分布式版本庫了。  如何從遠程庫克隆?  上面我們了解了先有本地庫,后有遠程庫時候,如何關聯遠程庫。  現在我們想,假如遠程庫有新的內容了,我想克隆到本地來 如何克隆呢?  首先,登錄github,創建一個新的倉庫,名字叫testgit2.如下:  1d10f3cc-593d-11ed-a3b6-dac502259ad0.jpg ? 如下,我們看到: ? 1d216996-593d-11ed-a3b6-dac502259ad0.jpg ? 現在,遠程庫已經準備好了,下一步是使用命令git clone克隆一個本地庫了。如下所示: ? 1d31a1b2-593d-11ed-a3b6-dac502259ad0.jpg ? 接著在我本地目錄下 生成testgit2目錄了,如下所示: ? 1d3d831a-593d-11ed-a3b6-dac502259ad0.jpg ? 六:創建與合并分支  在 版本回填退里,你已經知道,每次提交,Git都把它們串成一條時間線,這條時間線就是一個分支。截止到目前,只有一條時間線,在Git里,這個分支叫主分支,即master分支。HEAD嚴格來說不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是當前分支。  首先,我們來創建dev分支,然后切換到dev分支上。如下操作:  1d5608a4-593d-11ed-a3b6-dac502259ad0.jpg ? git checkout命令加上 –b參數表示創建并切換,相當于如下2條命令 ?

git branch dev

git checkout dev

git branch查看分支,會列出所有的分支,當前分支前面會添加一個星號。然后我們在dev分支上繼續做demo,比如我們現在在readme.txt再增加一行 7777777777777 首先我們先來查看下readme.txt內容,接著添加內容77777777,如下: 1d61cec8-593d-11ed-a3b6-dac502259ad0.jpg ? 現在dev分支工作已完成,現在我們切換到主分支master上,繼續查看readme.txt內容如下: ? 1d70f7cc-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我們可以把dev分支上的內容合并到分支master上了,可以在master分支上,使用如下命令git merge dev?如下所示: ? 1d7ef228-593d-11ed-a3b6-dac502259ad0.jpg ? git merge命令用于合并指定分支到當前分支上,合并后,再查看readme.txt內容,可以看到,和dev分支最新提交的是完全一樣的。 ? 注意到上面的Fast-forward信息,Git告訴我們,這次合并是“快進模式”,也就是直接把master指向dev的當前提交,所以合并速度非常快。 ? 合并完成后,我們可以接著刪除dev分支了,操作如下: ? 1d8d3072-593d-11ed-a3b6-dac502259ad0.jpg ? 總結創建與合并分支命令如下: ?

查看分支:git branch

創建分支:git branch name

切換分支:git checkout name

創建+切換分支:git checkout –b name

合并某分支到當前分支:git merge name

刪除分支:git branch –d name

如何解決沖突? 下面我們還是一步一步來,先新建一個新分支,比如名字叫fenzhi1,在readme.txt添加一行內容8888888,然后提交,如下所示: 1d985b82-593d-11ed-a3b6-dac502259ad0.jpg ? 同樣,我們現在切換到master分支上來,也在最后一行添加內容,內容為99999999,如下所示: ? 1da873aa-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我們需要在master分支上來合并fenzhi1,如下操作: ? 1db794c0-593d-11ed-a3b6-dac502259ad0.jpg ? Git用<<<<<<<,=======,>>>>>>>標記出不同分支的內容,其中<<>>>>fenzhi1 是指fenzhi1上修改的內容,我們可以修改下如下后保存: 1dd309da-593d-11ed-a3b6-dac502259ad0.jpg ? 如果我想查看分支合并的情況的話,需要使用命令 git log.命令行演示如下: ? 1ddfeee8-593d-11ed-a3b6-dac502259ad0.jpg ? 3.分支管理策略 通常合并分支時,git一般使用”Fast forward”模式,在這種模式下,刪除分支后,會丟掉分支信息,現在我們來使用帶參數 –no-ff來禁用”Fast forward”模式。首先我們來做demo演示下:

創建一個dev分支。

修改readme.txt內容。

添加到暫存區。

切換回主分支(master)。

合并dev分支,使用命令 git merge –no-ff -m “注釋” dev

查看歷史記錄

截圖如下: 1df1bb96-593d-11ed-a3b6-dac502259ad0.jpg ? 分支策略:首先master主分支應該是非常穩定的,也就是用來發布新版本,一般情況下不允許在上面干活,干活一般情況下在新建的dev分支上干活,干完后,比如上要發布,或者說dev分支代碼穩定后可以合并到主分支master上來。 ? 七:bug分支 在開發中,會經常碰到bug問題,那么有了bug就需要修復,在Git中,分支是很強大的,每個bug都可以通過一個臨時分支來修復,修復完成后,合并分支,然后將臨時的分支刪除掉。 比如我在開發中接到一個404 bug時候,我們可以創建一個404分支來修復它,但是,當前的dev分支上的工作還沒有提交。比如如下: 1e0a7492-593d-11ed-a3b6-dac502259ad0.jpg ? 并不是我不想提交,而是工作進行到一半時候,我們還無法提交,比如我這個分支bug要2天完成,但是我issue-404 bug需要5個小時內完成。怎么辦呢?還好,Git還提供了一個stash功能,可以把當前工作現場 ”隱藏起來”,等以后恢復現場后繼續工作。如下: ? 1e1ee300-593d-11ed-a3b6-dac502259ad0.jpg ? 所以現在我可以通過創建issue-404分支來修復bug了。 ? 首先我們要確定在那個分支上修復bug,比如我現在是在主分支master上來修復的,現在我要在master分支上創建一個臨時分支,演示如下: ? 1e2de292-593d-11ed-a3b6-dac502259ad0.jpg ? 修復完成后,切換到master分支上,并完成合并,最后刪除issue-404分支。演示如下: ? 1e428922-593d-11ed-a3b6-dac502259ad0.jpg ? 現在,我們回到dev分支上干活了。 ? 1e5792ea-593d-11ed-a3b6-dac502259ad0.jpg ? 工作區是干凈的,那么我們工作現場去哪里呢?我們可以使用命令?git stash list來查看下。如下: ? 1e66816a-593d-11ed-a3b6-dac502259ad0.jpg ? 工作現場還在,Git把stash內容存在某個地方了,但是需要恢復一下,可以使用如下2個方法: ?

git stash apply恢復,恢復后,stash內容并不刪除,你需要使用命令git stash drop來刪除。

另一種方式是使用git stash pop,恢復的同時把stash內容也刪除了。

演示如下 1e734012-593d-11ed-a3b6-dac502259ad0.jpg ? 八:多人協作 ? 當你從遠程庫克隆時候,實際上Git自動把本地的master分支和遠程的master分支對應起來了,并且遠程庫的默認名稱是origin。 ?

要查看遠程庫的信息 使用 git remote

要查看遠程庫的詳細信息 使用 git remote –v

如下演示: 1e8624ac-593d-11ed-a3b6-dac502259ad0.jpg ? 一:推送分支: 推送分支就是把該分支上所有本地提交到遠程庫中,推送時,要指定本地分支,這樣,Git就會把該分支推送到遠程庫對應的遠程分支上:使用命令git push origin master 比如我現在的github上的readme.txt代碼如下: 1e944e60-593d-11ed-a3b6-dac502259ad0.jpg ? 本地的readme.txt代碼如下: ? 1ea69f34-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我想把本地更新的readme.txt代碼推送到遠程庫中,使用命令如下: ? 1ebc5d74-593d-11ed-a3b6-dac502259ad0.jpg ? 我們可以看到如上,推送成功,我們可以繼續來截圖github上的readme.txt內容 如下: ? 1ecb9a1e-593d-11ed-a3b6-dac502259ad0.jpg ? 可以看到 推送成功了,如果我們現在要推送到其他分支,比如dev分支上,我們還是那個命令 git push origin dev ? 那么一般情況下,那些分支要推送呢? ? master分支是主分支,因此要時刻與遠程同步。 ? 一些修復bug分支不需要推送到遠程去,可以先合并到主分支上,然后把主分支master推送到遠程去。 ? 二:抓取分支: 多人協作時,大家都會往master分支上推送各自的修改。現在我們可以模擬另外一個同事,可以在另一臺電腦上(注意要把SSH key添加到github上)或者同一臺電腦上另外一個目錄克隆,新建一個目錄名字叫testgit2 但是我首先要把dev分支也要推送到遠程去,如下 1ee514b2-593d-11ed-a3b6-dac502259ad0.jpg ? 接著進入testgit2目錄,進行克隆遠程的庫到本地來,如下: ? 1ef73516-593d-11ed-a3b6-dac502259ad0.jpg ? 現在目錄下生成有如下所示: ? 1f01b9b4-593d-11ed-a3b6-dac502259ad0.jpg ? 現在我們的小伙伴要在dev分支上做開發,就必須把遠程的origin的dev分支到本地來,于是可以使用命令創建本地dev分支: ?


git checkout –b dev origin/dev   現在小伙伴們就可以在dev分支上做開發了,開發完成后把dev分支推送到遠程庫時。  如下:  1f1c3c80-593d-11ed-a3b6-dac502259ad0.jpg ? 小伙伴們已經向origin/dev分支上推送了提交,而我在我的目錄文件下也對同樣的文件同個地方作了修改,也試圖推送到遠程庫時,如下: ? 1f390914-593d-11ed-a3b6-dac502259ad0.jpg ? 由上面可知:推送失敗,因為我的小伙伴最新提交的和我試圖推送的有沖突,解決的辦法也很簡單,上面已經提示我們,先用git pull把最新的提交從origin/dev抓下來,然后在本地合并,解決沖突,再推送。 ? 1f503c56-593d-11ed-a3b6-dac502259ad0.jpg ? git pull也失敗了,原因是沒有指定本地dev分支與遠程origin/dev分支的鏈接,根據提示,設置dev和origin/dev的鏈接:如下: ? 1f5bab04-593d-11ed-a3b6-dac502259ad0.jpg ? 這回git pull成功,但是合并有沖突,需要手動解決,解決的方法和分支管理中的 解決沖突完全一樣。解決后,提交,再push: ? 我們可以先來看看readme.txt內容了。 ? 1f6df246-593d-11ed-a3b6-dac502259ad0.jpg ? 現在手動已經解決完了,我接在需要再提交,再push到遠程庫里面去。如下所示: ? 1f843ace-593d-11ed-a3b6-dac502259ad0.jpg ? 因此:多人協作工作模式一般是這樣的: ?

首先,可以試圖用git push origin branch-name推送自己的修改.

如果推送失敗,則因為遠程分支比你的本地更新早,需要先用git pull試圖合并。

如果合并有沖突,則需要解決沖突,并在本地提交。再用git push origin branch-name推送。

審核編輯:彭靜
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 控制系統
    +關注

    關注

    41

    文章

    6661

    瀏覽量

    110891
  • 服務器
    +關注

    關注

    12

    文章

    9308

    瀏覽量

    86071
  • Git
    Git
    +關注

    關注

    0

    文章

    201

    瀏覽量

    15821

原文標題:Git使用教程:最詳細、最傻瓜、最淺顯、真正手把手教

文章出處:【微信號:技術讓夢想更偉大,微信公眾號:技術讓夢想更偉大】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    版本控制器,我裝了GITSVN 為什么這邊都沒顯示?

    我裝了GITSVN 為什么這邊都沒顯示?
    發表于 11-27 11:32

    為什么GitSVN拍在了沙灘上?精選資料分享

    GitSVN是大家都比較熟知的版本管理,近幾年Git越來越受到大家的喜歡。下面就來分享下關于GitSVN的內容。
    發表于 07-20 06:49

    FLASH存儲器與SRAM最主要區別是什么

    概念理解:FLASH存儲器又成為閃存,它與EEPROM都是掉電后數據不丟失的存儲器,但是FLASH得存儲容量都普遍的大于EEPROM,,在存儲控制上,最主要區別是FLASH芯片只能一大片一大片
    發表于 03-02 07:20

    SVN,HG,GIT命令對照

    SVN,HG,GIT是三種常見的版本控制系統,本文簡單列出一些相似的操作命令。當然,三種系統各有特點,嚴格的對應關系是沒有的。1,第一次下載,包括源碼和版本庫: svn checkout http
    發表于 01-13 16:53 ?0次下載

    SVN_DBLib

    SVN DBLib,好東西,喜歡的朋友可以下載來學習。
    發表于 02-18 16:17 ?0次下載

    關于SVN的例程講解

    SVN 的一些例程
    的頭像 發表于 07-11 00:03 ?2334次閱讀

    SVNGit最主要區別?在windows上如何安裝Git

    Git是分布式版本控制系統,那么它就沒有中央服務器的,每個人的電腦就是一個完整的版本庫,這樣,工作的時候就不需要聯網了,因為版本都是在自己的電腦上。既然每個人的電腦都有一個完整的版本庫,那多個
    的頭像 發表于 01-24 16:54 ?6212次閱讀
    <b class='flag-5'>SVN</b>與<b class='flag-5'>Git</b>的<b class='flag-5'>最主要</b>的<b class='flag-5'>區別</b>?在windows上如何安裝<b class='flag-5'>Git</b>?

    Git命令的講解和Git數據通信原理的資料概述

    Git是一款開源的分布式版本控制系統(VCS),常用的VCS工具還包括SVN、Mercurial等,他們的使命是對資源變化的進行版本管理控制,對資源容災備份,支持多域協同開發。這里的資源不僅僅是系統
    發表于 06-11 08:00 ?7次下載
    <b class='flag-5'>Git</b>命令的講解和<b class='flag-5'>Git</b>數據通信原理的資料概述

    SVNGit最主要區別

    Git是目前世界上最先進的分布式版本控制系統。
    發表于 07-08 10:46 ?5440次閱讀

    Git在實際工作中的基本使用方法

    代碼版本控制對于我們嵌入式軟件開發崗是一項基礎、必備的技能,需要熟練掌握。實際工作中常用的版本控制系統有:Git(分布式版本控制系統)與SVN(集中式版本控制系統)。 本次分享Git在實際工作
    的頭像 發表于 09-14 18:12 ?2617次閱讀

    為什么說GitSVN拍在沙灘上了呢?

    不同的體驗。 一、Git是分布式的,SVN是集中式的 這是 GitSVN 最大的區別。若能掌握這個概念,兩者
    的頭像 發表于 04-30 11:57 ?1524次閱讀
    為什么說<b class='flag-5'>Git</b>把<b class='flag-5'>SVN</b>拍在沙灘上了呢?

    Git最佳實踐,什么才是最佳工作流

    知道相比于 SvnGit 最牛的地方在于它的分支,分支很靈活,但是如果缺乏一個使用套路,又會用的亂糟糟的,特別是在團隊協作中,該怎么玩 Git 分支? 咱們也不發明什么輪子,也不設計什么全新流程,本文
    的頭像 發表于 02-21 17:59 ?1590次閱讀

    如何設置Git的SSH秘鑰

    現在使用Git工具的人是越來越多了,許多的公司或組織都使用了Git進行代碼的保存、項目管理、多人協作開發等,應用的也是越發的廣泛了。我個人的使用感覺來看,以前也是用SVN進行代碼托管,但是自從使用了
    的頭像 發表于 02-10 11:30 ?1939次閱讀
    如何設置<b class='flag-5'>Git</b>的SSH秘鑰

    git rebase和git merge的區別

    ? 解決沖突 git rebase和git merge的區別 分支合并 git merge是用來合并兩個分支的。 比如:將 b 分支合并到當前分支。 同樣
    的頭像 發表于 07-05 09:54 ?703次閱讀
    <b class='flag-5'>git</b> rebase和<b class='flag-5'>git</b> merge的<b class='flag-5'>區別</b>
    豪享博百家乐的玩法技巧和规则 | 游戏百家乐官网的玩法技巧和规则 | 威尼斯人娱乐场老品牌| 飞七棋牌游戏下载 | 如何打百家乐官网的玩法技巧和规则| 百家乐最佳投注法下载| 大发888在线娱乐下载| 百家乐官网玩法有技巧| 百家乐官网谋略| 百家乐平点| 皇冠现金网安全吗| 百家乐官网787| 最大的百家乐网站| 七胜百家乐娱乐网| 娱乐城体验金| 百家乐官网说明| 利博百家乐破解| 松阳县| 百家乐金海岸娱乐| 大发888线上| 百家乐官网双龙出海| 大丰收百家乐的玩法技巧和规则| 丰县| 手机| 澳门百家乐网站bt| 沈阳盛京棋牌官网| 怎样看百家乐官网路纸| 百家乐7赢6| 南溪县| 百家乐试玩活动| 大发888大法8668| 百家乐官网技巧-百家乐官网开户指定代理网址 | 百家乐赌博策略论坛| 连环百家乐| 杨公风水24山| 大发888加盟合作| 百家乐官网赌场导航| 百家乐开户送10彩金| 凤山县| 百家乐官网庄89| 百家乐娱乐礼金|