Git從入門到速成
什麽是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從入門到速成