1. 程式人生 > >Git從入門到速成

Git從入門到速成

有時 大神 merge 必須 更改 提示 團隊 怎麽學 change

什麽是Git

Git是Linux發明者Linus開發的一款新時代的版本控制系統,那什麽是版本控制系統呢?怎麽理解?網上一大堆詳細的介紹,但是大多枯燥乏味,對於新手也很難理解,這裏我只舉幾個例子。

熟悉編程的都知道,我們在軟件開發中源代碼其實是最重要的,那麽對源代碼的管理變得異常重要:

  • 為了防止代碼的丟失,肯定本地機器與遠程服務器都要存放一份,而且還需要有一套機制讓本地可以跟遠程同步;
  • 我們開發的時候免不了有bug,有時候剛發布的功能就出現了嚴重的bug,這個時候需要對代碼進行還原;
  • 隨著我們版本叠代的功能越來越多,但是我們需要清除的知道歷史每一個版本的代碼更改記錄,甚至知道每個人歷史提交代碼的情況

等等類似以上的情況,這些都是版本控制系統能解決的問題。所以說,版本控制是一種記錄一個或者若幹個文件內容變換,以便將來查閱特定版本修改情況的系統,對於軟件開發領域來說版本控制是最重要的一個環節,而Git是當下比較流行、好用的版本控制系統。

Git安裝

上面說了,Git是一個版本控制系統,你也可以理解成一個工具,跟Java類似,使用之前必須得先安裝,所以第一步必須要安裝,由於我用的是Mac,Mac上系統自帶Git。所以安裝這一步驟就省略,相信大家可以搞的定。

如何學習Git

安裝好Git之後,怎麽學習是個問題,其實關於Git有很多圖形化的軟件,但是我強烈建議大家從命令行開始學習理解,我知道沒有接觸過命令行的同學內心可能是拒絕的,但是我的親身實踐證明,只有一開始學習命令行,之後你對Git的每一步操作才能理解其意義,而等你熟練之後 ,你想用任何的圖形化的軟件去操作完全沒有問題。

Git命令列表

怎麽判斷你Git有沒有安裝成功呢?請在命令行裏輸入git,如果出現以下提示證明你已經安裝成功了。

技術分享圖片

Git所有的操作命令都是以git開頭,上面列舉了最常用的一些Git命令,緊接著會有一句引文解釋這個命令的意思,都不是很難理解的單詞,不妨試著看一下,不過沒有實際操作你仍然不好理解,下面我們來以一個實際的操作來介紹下一些常用的命令的含義。

Git具體命令

第一步:我們先新建一個文件夾,在文件夾裏新建一個文件(ps:我是用命令行去新建的)

  • 新建文件夾:mkdir test

  • 跳轉到文件夾目錄:cd test

  • 新建test.md文件: touch test.md

提醒:在進行任何Git操作之前,都要先切換到Git倉庫目錄,也就是要先切換到項目的文件夾目錄下

這個時候我們先隨便操作一個命令,比如git status,可以看到如下提示:
技術分享圖片

意思就是當前目錄還不是一個Git倉庫。

git init

這個時候用到了第一個命令,代表初始化git倉庫,輸入git init之後會提示:
技術分享圖片

可以看到初始化成功了,至此test目錄已經是一個git倉庫了。

git status

緊接著我們輸入git status命令,會有如下提示:
技術分享圖片

默認就直接在master分支,關於分支的概念後面會提,這時最主要的是提示test.md這個文件
Untracked files就是說test.md這個文件還沒有被跟蹤,還沒有提交在git倉庫裏呢,而且提示你可以用git add去操作你想要提交的文件。

git status這個命令就是查看狀態,這個命令可以算是使用最頻繁的了,建議大家沒事就輸入這個命令來查看你當前git倉庫的一些狀態。

git add

上面提示test.md文件還沒有提交到git倉庫裏,這個時候我們可以隨便編輯下test.md文件,然後輸入git add test.md,然後再輸入git status
技術分享圖片

此時提示以下文件 Changes to be committed,意思就是test.md文件等待被提交,當然你也可以使用 git rm -cached這個命令去移除這個緩存。

git commit

接著,我們輸入 git commit -m "first commit",這個命令是什麽意思呢?commit是提交的意思,-m 代表提交信息,執行了以上命令代表我們已經正式進行了第一次提交。這個時候再輸入 git status ,會提示 nothing to commit
技術分享圖片

git log

這個時候,我們輸入 git log命令,就會看到如下:
技術分享圖片

git log這個命令可以查看所有commit產生的記錄,所以可以看到已經產生了一條commit記錄,而提交時候的附帶信息叫 “first commit”

git add & git commit

看到這裏估計很多人都會有疑問,我想要提交直接進行commit不就行了麽為什麽需要先add一次呢?首先 git add 是把改動添加到一個暫存區,你可以理解成一個緩存區域,臨時保存你的改動,而 git commit 才是最後真正的提交,當然也有辦法把這兩步合並成一步,不過後面再介紹,建議新手先按部就班的一步步來。

git branch

branch即分支的意思,分支的概念很重要,尤其是團隊協作的時候,假設兩個人都做同一個項目,這個時候分支就是保證兩人能協同合作的最大力氣了。

舉個??:A、B兩人都在做同一個項目,但是不同的模塊,這個時候A新建了一個分支叫a,B新建了一個分支叫b,這樣A、B做的所有代碼改動都在各自的分支,互不影響,等到兩人都把各自的模塊都做完了,最後再統一把分支合並起來。

執行 git init初始化git倉庫之後會默認生成一個主分支master,也是你所在的默認分支,也基本是實際開發正式環境下的分支,一般情況下master分支不會輕易直接在上面操作的,你們可以輸入git branch查看下當前分支情況;如果我們想在此基礎上新建一個分支呢,很簡單,執行 git branch a就新建了一個名字叫a的分支,這時候分支a跟分支master是一模一樣的內容,我們再輸入git branch 查看當前的分支情況;

但是可以看到master分支前有個 * 號,(註意: * 所指的分支代表當前所在的分支) 即雖然新建了一個 a 的分支,但是當前所在的分支還是在master上,如果我們想在 a 分支上進行開發,首先要先切換到 a 分支上才行,所以下一步要切換分支。git checkout a
執行這個命令,然後再輸入git branch查看分支情況,可以看到當前我們所在的分支已經是a了,這個時候,A同學就可以在他新建的a分支進行寫代碼了。
那就有人說了,我要先新建再切換,未免有點麻煩,有沒有一步到位的,答案是肯定的:
git checkout -b a這個命令代表的意思就是新建一個a分支,並且自動切換到a分支

git merge

A同學在a分支上代碼寫完了,並且測試也OK了,準備要上線了,這個時候就需要把他的代碼合並到分支master上,然後發布。git merge就是合並分支用到的命令,這對這個情況,需要先做兩步:

  • 第一步是切換到master分支,如果你已經在那就不用切換了
  • 第二步執行git merge a,意思就是把 a 分支的代碼合並過來,不出意外,這個時候 a 分支的代碼就順利合並到master分支來了,為什麽說不出意外呢?因為這個時候可能因為產生沖突而導致合並失敗。

git branch -d

有新建分支,那肯定就有刪除分支,加入這個分支新建錯了,或者a分支的代碼已經順利合並到master分支來了,那麽a分支沒用了,需要刪除,這個時候執行代碼 git branch -d a
就可以把a分支刪除了。

git branch -D

有些時候可能會刪除失敗,比如如果a分支的代碼還沒有合並到master分支,你執行 git branch -d a是刪除不了的,它會智能的提示你a分支還有未合並的代碼,但是如果你非要刪除,那就執行 git branch -D a就可以強制刪除a分支了。

git tag

我們在客戶端開發的時候經常有版本的概念,比如v1.0、v1.1之類的,不同的版本肯定對應不同的代碼,所以我們一般要給我們的代碼加上標簽,這樣假設v1.1版本出了一個新bug,但是又不知道v1.0是不是有這個bug,有了標簽就可以順利切換到v1.0的代碼,重新打個包測試就知道了。
所以如果想要新建一個標簽很簡單,比如 git tag v1.0就代表我在當前代碼狀態下新建了一個v1.0的標簽,輸入 git tag可以查看歷史tag記錄。

想要切換到某個tag怎麽辦?
也很簡單,執行 git checkout v1.0這樣就順利的切換到v1.0 tag的代碼狀態了。

結束語

OK,以上全是一些最基本的git操作,而且全是在本地環境進行操作的,完全沒有涉及到遠程倉庫。畢竟這篇文章是針對小白的,大神可以忽略。

附上一張git操作的圖
技術分享圖片

Git從入門到速成