從零開始一個 git 操作實例,圖文並茂

徒弟不懂 git 怎麼用,

於是寫了篇文章,

把本地 git 操作從頭寫了一遍,

自己去看吧!

0、基本概念

•Git 是一個免費、開源的、分佈式版本控制系統

• 它使用一個特殊的叫做倉庫的數據庫來記錄文件的變化

• 倉庫中的每個文件都有一個完整的版本歷史記錄

1)安裝

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

2)工作流轉

Git 管理項目時,文件流轉的三個工作區域:Git 的工作目錄,暫存區域,以及本地倉庫。

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

3)文件 3 種狀態

對於任何一個文件,在 Git 內都只有三種狀態:已修改(modified),已暫存(staged)和已提交(committed)

一、創建倉庫並提交第 1 個 commit

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

1、創建倉庫

使用當前目錄作爲 Git 倉庫,我們只需使它初始化。

git init

該命令執行完後會在當前目錄生成一個 .git 目錄。

2、新建本地文件

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

實用 git status 查看文件狀態,紅色部分,有 2 個未跟蹤的在文件

3、提交文件到暫存區 git add

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

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

執行下面操作:

git add *.c 
git add README.md

4、提交改動 git commit

使用如下命令以實際提交改動:

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

或者

git commit

然後進入 vim 編輯器,添加提交信息

例如:

git commit -m '初始化項目版本'

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

現在,剛纔的改動已經提交到了 HEAD,但是還沒到遠端倉庫。

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

5、推送改動 git push

剛纔的改動現在已經在本地倉庫的 HEAD 中了。

執行如下命令以將這些改動提交到遠端倉庫

git push origin master

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

如果你還沒有克隆現有倉庫,並欲將你的倉庫連接到某個遠程服務器,你可以使用如下命令添加:

git remote add origin <server>

如此你就能夠將你的改動推送到所添加的服務器上去了。

三、 分支操作

分支是用來將特性開發絕緣開來的。在你創建倉庫的時候,master 是 "默認的" 分支

在其他分支上進行開發,完成後再將它們合併到主分支上。

0)查看分支

列出分支基本命令:

git branch

沒有參數時,git branch 會列出你在本地的分支。

此例的意思就是,我們有一個叫做 master 的分支,並且該分支是當前分支。 執行 git init 的時候,默認情況下 Git 就會爲你創建 master 分支。 分支在本地完成,速度快。

1)創建分支

要創建一個新的分支,我們使用 branch 命令。

git branch test

由上圖所示:

  1. 多了一個分支 test

  2. 當前分支爲主分支 master,前面 * 表示活動分支

2)切換分支

branch 命令不會將我們帶入分支,只是創建一個新分支。所以我們使用 checkout 命令來更改分支。

git checkout test

創建一個叫做 "test" 的分支,並切換過去:

git checkout -b test

如上圖所示:

  1. 分支 test 前面有 *,所以當前活動分支爲 master

分支創建和切換參考下圖:

3)切回 master 分支併合並

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

切換回主分支併合並

git checkout master
git merge test

由上圖所示,git merge test 後,主分支多了一個新的 commit b9217

注意:

對其他分支的更改不會反映在主分支上。如果想將更改提交到主分支,則需切換回 master 分支,然後使用合併。

4)刪除分支

使用 - d 標識,把新建的分支刪掉:

git branch -d test
git branch -D test

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

5)上傳分支 push

除非你將分支推送到遠端倉庫,不然該分支就是 不爲他人所見的:

git push origin <branch>

四、替換本地改動 git checkout

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

git checkout -- <filename>

此命令會使用 HEAD 中的最新內容替換掉你的工作目錄中的文件

已添加到暫存區的改動以及新文件都不會受到影響。

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

//this change will be delete by git checkout

然後再 git checkout url.c

如上圖所示,

執行下面命令後:

git checkout url.c

url.c 修改的信息

//this change will be delete by git checkout

已經被刪除了,此時工作區域文件還原到了 commitb 9217 狀態

查看 url.c:

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

git fetch origin
git reset --hard origin/master

五、重置 git reset

當我們不想要之前提交的修改時,就會用到這個命令。也許這是一個 錯誤的提交或者可能是引入了 bug 的提交,這時候就要執行 git reset。

git reset 能讓我們不再使用當前檯面上的文件,讓我們可以控制 HEAD 應該指向的位置。

1)軟重置

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

輸入 git status 後,你會看到我們仍然可以訪問在之前的提交上做過的所有修改。

這意味着我們可以修復這些文件的內容,之後再重新提交它們!

2)硬重置

有時候我們並不想保留特定提交引入的修改。不同於軟重置,我們應該再也無需訪問它們。

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

我們重新 add 並 commit,然後硬重置

可見我們所有提交的信息都已經被移除,

工作區域文件恢復到 commit 7bb299 狀態。

打開文件,查看,添加信息已經不存在,

六、還原 git revert

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

通過對特定的提交執行還原操作,我們會創建一個包含已還原修改的新提交。

新創建文件 peng.c 並提交

用 git revert 撤銷修改

由上圖所示,執行 git revert 209485 之後,我們新增的文件 peng.c 被刪除,並提交了 1 個新的 commit 5b08d

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

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

七、揀選 git cherry-pick

當一個特定分支包含我們的活動分支需要的某個提交時,我們對那個提交執行 cherry-pick!

對一個提交執行 cherry-pick 時,我們會在活動分支上創建一個新的提交,其中包含由揀選出來的提交所引入的修改。

創建切換到 cherry 分支,

git branch cherry
git checkout cherry

在分支 cherry 上修改文件 README.md 提交幾個節點

切回 master 分支

git checkout master

執行 git cherry-pick b98fc77

由上圖所示,分支 cherry 的 commit  b98fc77,被複制到分支 master,並創建了 1 個新的提交 2d995,

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

本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源https://mp.weixin.qq.com/s/mKMlxcO_MeWLU0ktyFLcJA