加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 0、基本概念
    • 一、創(chuàng)建倉庫并提交第1個(gè)commit
    • 三、 分支操作
    • 四、替換本地改動(dòng)git checkout
    • 五、重置git reset
    • 六、還原git revert
    • 七、揀選git cherry-pick
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請(qǐng)入駐 產(chǎn)業(yè)圖譜

從零開始一個(gè)git操作實(shí)例,圖文并茂

08/27 10:20
1297
閱讀需 12 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

徒弟不懂git怎么用,于是寫了篇文章,把本地git操作從頭寫了一遍,自己去看吧!

0、基本概念

?Git是一個(gè)免費(fèi)、開源的、分布式版本控制系統(tǒng)

?它使用一個(gè)特殊的叫做倉庫的數(shù)據(jù)庫來記錄文件的變化

?倉庫中的每個(gè)文件都有一個(gè)完整的版本歷史記錄

1)安裝

sudo?apt-update
sudo?apt-get?install?git
git?--version

2)工作流轉(zhuǎn)

Git 管理項(xiàng)目時(shí),文件流轉(zhuǎn)的三個(gè)工作區(qū)域:Git 的工作目錄,暫存區(qū)域,以及本地倉庫。

你的本地倉庫由 git 維護(hù)的三棵"樹"組成。

工作目錄:它持有實(shí)際文件;

暫存區(qū)(Index):它像個(gè)緩存區(qū)域,臨時(shí)保存你的改動(dòng);

本地倉庫(Respository):可以把本地倉庫理解成一個(gè)目錄,這個(gè)目錄中所有的文件都可以被Git管理起來

每個(gè)文件的刪除、修改、新增操作都可以被Git跟蹤到

以便任何時(shí)候,都可以追蹤歷史或者還原到之前的某一個(gè)版本

HEAD,它指向你最后一次提交的結(jié)果。

3)文件3種狀態(tài)

對(duì)于任何一個(gè)文件,在 Git 內(nèi)都只有三種狀態(tài):已修改(modified),已暫存(staged)和已提交(committed)。

    已修改表示修改了某個(gè)文件,但還沒有提交保存;已暫存表示把已修改的文件放在下次提交時(shí)要保存的清單中; add已提交表示該文件已經(jīng)被安全地保存在本地?cái)?shù)據(jù)庫中了。commit

一、創(chuàng)建倉庫并提交第1個(gè)commit

步驟1-4流程,參考下圖流程會(huì)更清晰一些

1、創(chuàng)建倉庫

使用當(dāng)前目錄作為Git倉庫,我們只需使它初始化。

git?init

該命令執(zhí)行完后會(huì)在當(dāng)前目錄生成一個(gè) .git 目錄。

2、新建本地文件

本地增加文件url.c、README.md

實(shí)用git status查看文件狀態(tài),紅色部分,有2個(gè)未跟蹤的在文件

3、提交文件到暫存區(qū)git add

你可以提出更改(把它們添加到暫存區(qū)),使用如下命令:

git?add?<filename>
git?add?.??????//添加所有文件
git?add?*.c????//添加所有c文件

執(zhí)行下面操作:

git?add?*.c?
git?add?README.md

4、提交改動(dòng)git commit

使用如下命令以實(shí)際提交改動(dòng):

git?commit?-m?"代碼提交信息"

或者

git?commit

然后進(jìn)入vim編輯器,添加提交信息

例如:

git?commit?-m?'初始化項(xiàng)目版本'

以上命令將目錄下以 .c 結(jié)尾及 README 文件提交到倉庫中。

現(xiàn)在,剛才的改動(dòng)已經(jīng)提交到了 HEAD,但是還沒到遠(yuǎn)端倉庫。

可以使用git log查看所有的提交:

5、推送改動(dòng)git push

剛才的改動(dòng)現(xiàn)在已經(jīng)在本地倉庫的 HEAD 中了。

執(zhí)行如下命令以將這些改動(dòng)提交到遠(yuǎn)端倉庫

git?push?origin?master

可以把 master 換成你想要推送的任何分支。

如果你還沒有克隆現(xiàn)有倉庫,并欲將你的倉庫連接到某個(gè)遠(yuǎn)程服務(wù)器,你可以使用如下命令添加:

git?remote?add?origin?<server>

如此你就能夠?qū)⒛愕母膭?dòng)推送到所添加的服務(wù)器上去了。

三、 分支操作

分支是用來將特性開發(fā)絕緣開來的。在你創(chuàng)建倉庫的時(shí)候,master 是"默認(rèn)的"分支。

在其他分支上進(jìn)行開發(fā),完成后再將它們合并到主分支上。

0)查看分支

列出分支基本命令:

git?branch

沒有參數(shù)時(shí),git branch 會(huì)列出你在本地的分支。

此例的意思就是,我們有一個(gè)叫做 master 的分支,并且該分支是當(dāng)前分支。
執(zhí)行 git init 的時(shí)候,默認(rèn)情況下 Git 就會(huì)為你創(chuàng)建 master 分支。
分支在本地完成,速度快。

1)創(chuàng)建分支

要?jiǎng)?chuàng)建一個(gè)新的分支,我們使用branch命令。

git?branch?test

由上圖所示:

    多了一個(gè)分支test當(dāng)前分支為主分支master,前面*表示活動(dòng)分支

2)切換分支

branch命令不會(huì)將我們帶入分支,只是創(chuàng)建一個(gè)新分支。所以我們使用checkout命令來更改分支。

git?checkout?test

創(chuàng)建一個(gè)叫做"test"的分支,并切換過去:

git?checkout?-b?test

如上圖所示:

    分支test前面有*,所以當(dāng)前活動(dòng)分支為master

分支創(chuàng)建和切換參考下圖:

3)切回master分支并合并

在分支test上,修改文件url.c,然后commit

切換回主分支并合并

git?checkout?master
git?merge?test

由上圖所示,git merge test后,主分支多了一個(gè)新的commit b9217

注意:

對(duì)其他分支的更改不會(huì)反映在主分支上。如果想將更改提交到主分支,則需切換回master分支,然后使用合并。

4)刪除分支

使用-d標(biāo)識(shí),把新建的分支刪掉:

git?branch?-d?test
git?branch?-D?test

如上圖,我們刪除了分支test

5)上傳分支push

除非你將分支推送到遠(yuǎn)端倉庫,不然該分支就是 不為他人所見的:

git?push?origin?<branch>

四、替換本地改動(dòng)git checkout

假如操作失誤可以使用如下命令替換掉本地改動(dòng):

git?checkout?--?<filename>

此命令會(huì)使用 HEAD 中的最新內(nèi)容替換掉你的工作目錄中的文件。

已添加到暫存區(qū)的改動(dòng)以及新文件都不會(huì)受到影響。

    步驟

修改文件url.c,增加信息

//this?change?will?be?delete?by?git?checkout

然后再git checkout url.c

如上圖所示,執(zhí)行下面命令后:

git?checkout?url.c

url.c修改的信息

//this?change?will?be?delete?by?git?checkout

已經(jīng)被刪除了,此時(shí)工作區(qū)域文件還原到了commitb 9217狀態(tài)

查看url.c:

假如你想丟棄你在本地的所有改動(dòng)與提交,可以到服務(wù)器上獲取最新的版本歷史,并將你本地主分支指向它:

git?fetch?origin
git?reset?--hard?origin/master

五、重置git reset

當(dāng)我們不想要之前提交的修改時(shí),就會(huì)用到這個(gè)命令。也許這是一個(gè) 錯(cuò)誤的提交或者可能是引入了 bug 的提交,這時(shí)候就要執(zhí)行 git reset。

git reset 能讓我們不再使用當(dāng)前臺(tái)面上的文件,讓我們可以控制 HEAD 應(yīng)該指向的位置。

1)軟重置

軟重置會(huì)將 HEAD 移至指定的提交(或與 HEAD 相比的提交的索引),而不會(huì)移除該提交之后加入的修改!

輸入 git status 后,你會(huì)看到我們?nèi)匀豢梢栽L問在之前的提交上做過的所有修改。

這意味著我們可以修復(fù)這些文件的內(nèi)容,之后再重新提交它們!

2)硬重置

有時(shí)候我們并不想保留特定提交引入的修改。不同于軟重置,我們應(yīng)該再也無需訪問它們。

Git 應(yīng)該直接將整體狀態(tài)直接重置到特定提交之前的狀態(tài):這甚至包括你在工作目錄中和暫存文件上的修改。

我們重新add并commit,然后硬重置

可見我們所有提交的信息都已經(jīng)被移除,

工作區(qū)域文件恢復(fù)到commit 7bb299狀態(tài)。

打開文件,查看,添加信息已經(jīng)不存在,

六、還原git revert

另一種撤銷修改的方法是執(zhí)行 git revert。

通過對(duì)特定的提交執(zhí)行還原操作,我們會(huì)創(chuàng)建一個(gè)包含已還原修改的新提交。

新創(chuàng)建文件peng.c并提交

用git revert 撤銷修改

由上圖所示,執(zhí)行git revert 209485之后,我們新增的文件peng.c被刪除,并提交了1個(gè)新的commit 5b08d

此前添加peng.c文件的提交還在,這樣就保留了該提交信息,提高了倉庫的兼容性。

在撤銷特定的提交時(shí),git revert 非常有用,同時(shí)也不會(huì)修改分支的歷史。

七、揀選git cherry-pick

當(dāng)一個(gè)特定分支包含我們的活動(dòng)分支需要的某個(gè)提交時(shí),我們對(duì)那個(gè)提交執(zhí)行 cherry-pick!

對(duì)一個(gè)提交執(zhí)行 cherry-pick 時(shí),我們會(huì)在活動(dòng)分支上創(chuàng)建一個(gè)新的提交,其中包含由揀選出來的提交所引入的修改。

創(chuàng)建切換到cherry分支,

git?branch?cherry
git?checkout?cherry?

在分支cherry上修改文件README.md提交幾個(gè)節(jié)點(diǎn)

切回master分支

git?checkout?master

執(zhí)行git cherry-pick b98fc77

由上圖所示,分支cherry的commit ?b98fc77,被復(fù)制到分支master,并創(chuàng)建了1個(gè)新的提交2d995,

通過該命令我們就可以將其他分支,需要的提交,合并到主分支master。

推薦器件

更多器件
器件型號(hào) 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊(cè) ECAD模型 風(fēng)險(xiǎn)等級(jí) 參考價(jià)格 更多信息
PC357N1J000F 1 Sharp Corp Transistor Output Optocoupler, 1-Element, 3750V Isolation, ROHS COMPLIANT, PLASTIC, MINI-FLAT-4

ECAD模型

下載ECAD模型
$0.65 查看
ASVMB-12.000MHZ-LY-T 1 Abracon Corporation MEMS OSC XO 12.0000MHZ LVCMOS
$2.89 查看
SME2470-021 1 Honeywell Microelectronics & Precision Sensors Photo Transistor Detector, Surface Mount, 3.81 X 2.54 X 2.10 MM, CERAMIC PACKAGE-SME2470
$7.64 查看

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

公眾號(hào)『一口Linux』號(hào)主彭老師,擁有15年嵌入式開發(fā)經(jīng)驗(yàn)和培訓(xùn)經(jīng)驗(yàn)。曾任職ZTE,某研究所,華清遠(yuǎn)見教學(xué)總監(jiān)。擁有多篇網(wǎng)絡(luò)協(xié)議相關(guān)專利和軟件著作。精通計(jì)算機(jī)網(wǎng)絡(luò)、Linux系統(tǒng)編程、ARM、Linux驅(qū)動(dòng)、龍芯、物聯(lián)網(wǎng)。原創(chuàng)內(nèi)容基本從實(shí)際項(xiàng)目出發(fā),保持原理+實(shí)踐風(fēng)格,適合Linux驅(qū)動(dòng)新手入門和技術(shù)進(jìn)階。