你使用過 Git 嗎?也許你已經使用了一段時間,但它的許多奧秘仍然令人困惑。
Git 是一個版本控制系統,是任何軟件開發項目中的主要內容。通常有兩個主要用途:代碼備份和代碼版本控制。你可以逐步處理代碼,在需要回滾到備份副本的過程中保存每一步的進度!
常見的問題是 Git 很難使用。有時版本和分支不同步,你會花很長時間試圖推送代碼!更糟糕的是,不知道某些命令的確切工作方式很容易導致意外刪除或覆蓋部分代碼!
這就是我寫本文的原因,從而學習到如何正確使用 Git,以便在開發中共同進行編碼!
安裝和配置
Git 安裝
首先,我們必須安裝 Git 才能使用它!這里分 Linux 和 Windows 來演示:
在 Linux 上安裝 Git
我們可以使用 yum 輕松快速地做到這一點:
sudo yum install git
在 Windows 上安裝 Git
直接在 https://git-scm.com/downloads
里面,下載最新版的 Git,默認安裝就可以了。
安裝完成后,在開始菜單里找到 Git->Git Bash
,點擊后出現一個類似命令行窗口的東西,就說明 Git 安裝成功。
Git 配置
可以保存 Git 用戶名和電子郵件,這樣就不必在以后的 Git 命令中再次輸入它們。
在命令行中配置本地倉庫的賬號和郵箱:
$ git config --global user.name "wupx"
$ git config --global user.email "wupx@qq.com"
好多人都不知道的小技巧是,你可以為 Git 啟用一些額外的顏色,這樣就可以更容易地閱讀命令的輸出!
git config --global color.ui true
Git 基本版本控制
初始化 Git
現在,我們可以開始對項目進行版本控制。使用 cd 命令導航到要在終端中設置版本控制的目錄,現在你可以像這樣初始化 Git 存儲庫:
git init
這將創建一個名為 .git 的新子目錄(Windows 下該目錄為隱藏的),其中包含所有必需的存儲庫文件(Git 存儲庫框架)。至此,你的項目中尚未跟蹤任何內容。
添加並提交
要開始對現有文件進行版本控制,你應該先跟蹤這些文件並進行初始提交。要做到這一點,你首先需要將文件添加到 Git 中,並將它們附加到 Git 項目中。
git add <file>
git commit -m 'first commit'
遠程備份
很棒!你現在已經開始在本地對項目進行版本控制。如果你想遠程保存和備份項目,則需要在 GitHub 上創建一個遠程存儲庫(它是免費的!)。因此,首先轉到 github.com 並創建一個存儲庫。然后,使用存儲庫的鏈接將其添加為本地 git 項目的來源,即該代碼的存儲位置。
# 示例
git remote add origin \
https://github.com/wupeixuan/repo.git
# 以我的一個倉庫為例
git remote add origin \
https://github.com/wupeixuan/JDKSourceCode1.8.git
然后,你可以繼續將代碼推送到 GitHub!哇,你已經成功備份了你的代碼!
git push origin master
處理文件
狀態檢查
git status 命令用於確定哪些文件處於哪種狀態,它使你可以查看哪些文件已提交,哪些文件尚未提交。如果在所有文件都已提交並推送后運行此命令,則應該看到類似以下內容:
$ git status
# On branch master
nothing to commit (working directory clean)
如果你將新文件添加到項目中,而該文件之前不存在,則在運行 git status
時,你應該看到未跟蹤的文件,如下所示:
$ git status
# On branch master
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# README
nothing added to commit but untracked files present (use "git add" to track)
使用 git status
對於快速檢查你已經備份的內容和你僅在本地擁有的內容非常有用。
高級文件添加
還有一些更高級的方法可以將文件添加到 Git 中,從而使你的工作流程更高效。我們可以執行以下操作,而不是試圖查找所有有更改的文件並逐個添加它們:
# 逐個添加文件
git add filename
# 添加當前目錄中的所有文件
git add -A
# 添加當前目錄中的所有文件更改
git add .
# 選擇要添加的更改(你可以 Y 或 N 完成所有更改)
git add -p
高級提交
我們可以使用 git commit -m '提交信息'
來將文件提交到 Git。對於提交簡短消息來說,這一切都很好,但是如果你想做一些更精細的事情,你需要來學習更多的操作:
### 提交暫存文件,通常用於較短的提交消息
git commit -m 'commit message'
### 添加文件並提交一次
git commit filename -m 'commit message'
### 添加文件並提交暫存文件
git commit -am 'insert commit message'
### 更改你的最新提交消息
git commit --amend 'new commit message'
# 將一系列提交合並為一個提交,你可能會用它來組織混亂的提交歷史記錄
git rebase -i
### 這將為你提供核心編輯器上的界面:
# Commands:
# p, pick = use commit
# r, reword = use commit, but edit the commit message
# e, edit = use commit, but stop for amending
# s, squash = use commit, but meld into previous commit
# f, fixup = like "squash", but discard this commit's log message
# x, exec = run command (the rest of the line) using shell
分支與合並
GitHub存儲庫的master分支應始終包含有效且穩定的代碼。但是,你可能還希望備份一些當前正在處理的代碼,但這些代碼並不完全穩定。也許你要添加一個新功能,你正在嘗試和破壞很多代碼,但是你仍然希望保留備份以保存進度!
分支使你可以在不影響master分支的情況下處理代碼的單獨副本。首次創建分支時,將以新名稱創建master分支的完整克隆。然后,你可以獨立地在此新分支中修改代碼,包括提交文件等。一旦你的新功能已完全集成並且代碼穩定,就可以將其合並到master分支中!
分支
這是你在分支上創建和工作所需的所有東西:
### 創建一個本地分支
git checkout -b branchname
### 在2個分支之間切換
git checkout prc/dev-wupx
git checkout master
### 將新的本地分支作為備份
git push -u origin branch_2
### 刪除本地分支,這不會讓你刪除尚未合並的分支
git branch -d branch_2
### 刪除本地分支,即使尚未合並,這也會刪除該分支!
git branch -D branch_2
### Viewing all current branches for the repository, including both ### local and remote branches. Great to see if you already have a ### branch for a particular feature addition, especially on bigger ### projects
### 查看存儲庫的所有當前分支,包括本地和遠程分支。
git branch -a
### 查看已合並到您當前分支中的所有分支,包括本地和遠程。 非常適合查看所有代碼的來源!
git branch -a --merged
### 查看尚未合並到當前分支中的所有分支,包括本地和遠程
git branch -a --no-merged
### 查看所有本地分支
git branch
### 查看所有遠程分支
git branch -r
# 將主分支重新設置為本地分支
$ git rebase origin/master
# 將分支推送到遠程存儲庫源並對其進行跟蹤
$ git push origin branchname
合並
很棒!現在,你已經學習了如何創建分支並開始敲代碼!將新功能添加到分支中之后,你需要將其合並回master分支,以便您的master具有所有最新的代碼功能。
方法如下:
### 首先確保你正在查看 master 分支
git checkout master
### 現在將你的分支合並到 master
git merge prc/dev-wupx
你可能必須修復分支與主服務器之間的任何代碼沖突,但是 Git 將向你展示在鍵入該 merge 命令后如何執行所有這些操作。
修復錯誤和回溯
發生錯誤......它們經常在編碼中發生!重要的是我們能夠修復它們。
不要慌!Git 提供了你所需的一切,以防你在所推送的代碼中犯錯,改寫某些內容或者只是想對所推送的內容進行更正。
### 切換到最新提交的代碼版本
git reset HEAD
git reset HEAD -- filename # for a specific file
### 切換到最新提交之前的代碼版本
git reset HEAD^ -- filename
git reset HEAD^ -- filename # for a specific file
### 切換回3或5次提交
git reset HEAD~3 -- filename
git reset HEAD~3 -- filename # for a specific file
git reset HEAD~5 -- filename
git reset HEAD~5 -- filename # for a specific file
### 切換回特定的提交,其中 0766c053 為提交 ID
git reset 0766c053 -- filename
git reset 0766c053 -- filename # for a specific file
### 先前的命令是所謂的軟重置。 你的代碼已重置,但是git仍會保留其他代碼的副本,以備你需要時使用。 另一方面,--hard 標志告訴Git覆蓋工作目錄中的所有更改。
git reset --hard 0766c053
對 Git 有用的提示和技巧
我們已經完成了所有細節部分!以下是一些 Git 提示和技巧,你可能會發現它們對改善工作流程非常有用!
搜索
### 搜索目錄中的字符串部分
git grep 'project'
### 在目錄中搜索部分字符串,-n 打印出 git 找到匹配項的行號
git grep -n 'project'
### git grep -C <行數> 'something' 搜索帶有某些上下文的字符串部分(某些行在我們正在尋找的字符串之前和之后)
git grep -C<number of lines> 'project'
### 搜索字符串的一部分,並在字符串之前顯示行
git grep -B<number of lines> 'project'
### 搜索字符串的一部分,並在字符串之后顯示行
git grep -A<number of lines> 'something'
看誰寫了什么
### 顯示帶有作者姓名的文件的更改歷史記錄
git blame 'filename'
### 顯示帶有作者姓名和 git commit ID 的文件的更改歷史記錄
git blame 'filename' -l
日志
### 顯示存儲庫中所有提交的列表 該命令顯示有關提交的所有信息,例如提交ID,作者,日期和提交消息
git log
### 提交列表僅顯示提交消息和更改
git log -p
### 包含您要查找的特定字符串的提交列表
git log -S 'project'
### 作者提交的清單
git log --author 'wupx'
### 顯示存儲庫中提交列表的摘要。顯示提交ID和提交消息的較短版本。
git log --oneline
### 顯示昨天以來倉庫中的提交列表
git log --since=yesterday
### 顯示作者日志,並在提交消息中搜索特定術語
git log --grep "project" --author "wupx"