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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

教程8--分支

發(fā)布時間:2025/4/16 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 教程8--分支 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

作用

分支在實際中有什么用呢?假設(shè)你準(zhǔn)備開發(fā)一個新功能,但是需要兩周才能完成,第一周你寫了50%的代碼,如果立刻提交,由于代碼還沒寫完,不完整的代碼庫會導(dǎo)致別人不能干活了。如果等代碼全部寫完再一次提交,又存在丟失每天進(jìn)度的巨大風(fēng)險。 現(xiàn)在有了分支,就不用怕了。你創(chuàng)建了一個屬于你自己的分支,別人看不到,還繼續(xù)在原來的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到開發(fā)完畢后,再一次性合并到原來的分支上,這樣,既安全,又不影響別人工作。

原理

在版本回退里,你已經(jīng)知道,每次提交,Git都把它們串成一條時間線,這條時間線就是一個分支。截止到目前,只有一條時間線,在Git里,這個分支叫主分支,即master分支。HEAD嚴(yán)格來說不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是當(dāng)前分支。

圖解

一開始的時候,master分支是一條線,Git用master指向最新的提交,再用HEAD指向master,就能確定當(dāng)前分支,以及當(dāng)前分支的提交點:


每次提交,master分支都會向前移動一步,這樣,隨著你不斷提交,master分支的線也越來越長:
當(dāng)我們創(chuàng)建新的分支,例如dev時,Git新建了一個指針叫dev,指向master相同的提交,再把HEAD指向dev,就表示當(dāng)前分支在dev上:

Git創(chuàng)建一個分支很快,因為除了增加一個dev指針,改改HEAD的指向,工作區(qū)的文件都沒有任何變化!不過,從現(xiàn)在開始,對工作區(qū)的修改和提交就是針對dev分支了,比如新提交一次后,dev指針往前移動一步,而master指針不變:

假如我們在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最簡單的方法,就是直接把master指向dev的當(dāng)前提交,就完成了合并

所以Git合并分支也很快!就改改指針,工作區(qū)內(nèi)容也不變!合并完分支后,甚至可以刪除dev分支。刪除dev分支就是把dev指針給刪掉,刪掉后,我們就剩下了一條master分支:

具體操作

1、創(chuàng)建分支

命令:git checkout -b dev

2、查看當(dāng)前分支情況

命令:git branch


上面列出了所有分支,當(dāng)前分支前面會標(biāo)一個*號

3、開發(fā)

下面就在dev分支上繼續(xù)開發(fā),比如在某個文件(readme.txt)上作出修改然后,提交
git add readme.txt
git commit -m "分支測試"

4、切換分支

命令: git checkout master

切換回master分支后,再查看一個readme.txt文件,剛才添加的內(nèi)容不見了!因為那個提交是在dev分支上,而master分支此刻的提交點并沒有變:

5、合并分支

注意:必須在需要添加功能的分支,而不是開發(fā)分支。如:我們在dev分支上開發(fā)了新功能,要合并到主分支master,就要在dev上提交后再切換到master,然后在主分支上去合并dev分支;
命令:git merge dev

git merge命令用于合并指定分支到當(dāng)前分支。合并后,再查看readme.txt的內(nèi)容,就可以看到,和dev分支的最新提交是完全一樣的。注意到上面的Fast-forward信息,Git告訴我們,這次合并是“快進(jìn)模式”,也就是直接把master指向dev的當(dāng)前提交,所以合并速度非常快。當(dāng)然,也不是每次合并都能Fast-forward,我們后面會講其他方式的合并。合并完成后,就可以放心地刪除dev分支了:

6、刪除分支

命令:git branch -d dev刪除后,查看branch,就只剩下master分支了:

7、常用分支命令

查看分支:git branch創(chuàng)建分支:git branch <name>切換分支:git checkout <name>創(chuàng)建+切換分支:git checkout -b <name>合并某分支到當(dāng)前分支:git merge <name>刪除分支:git branch -d <name>

8、分支合并策略

在實際開發(fā)中,我們應(yīng)該按照幾個基本原則進(jìn)行分支管理:首先,master分支應(yīng)該是非常穩(wěn)定的,也就是僅用來發(fā)布新版本,平時不能在上面干活;那在哪干活呢?干活都在dev分支上,也就是說,dev分支是不穩(wěn)定的,到某個時候,比如1.0版本發(fā)布時,再把dev分支合并到master上,在master分支發(fā)布1.0版本;你和你的小伙伴們每個人都在dev分支上干活,每個人都有自己的分支,時不時地往dev分支上合并就可以了。所以,團(tuán)隊合作的分支看起來就像這樣:

轉(zhuǎn)載于:https://www.cnblogs.com/daxiang2008/p/10727444.html

總結(jié)

以上是生活随笔為你收集整理的教程8--分支的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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