Git的使用小結

初始化

首先,你需要執行下面兩條命令,作為git的基礎配置,作用是告訴git你是誰,你輸入的信息將出現在你創建的提交中.

git config --global user.name "你的名字或昵稱"
git config --global user.email "你的郵箱"

然后在你的需要初始化版本庫的文件夾中執行

git init 
git remote add origin http://git.oschina.net/xxx/xxx.git或者 git@git.oschina.net:xxx/xxx.git

這樣就完成了一次版本你的初始化,執行 了git init命令的目錄下會生成一個.git目錄。
這個.git目錄存著管理當前目錄內容所需的倉庫數據。
當前目錄也被稱為“附屬于該倉庫的工作樹”
git status 可查看工作樹和倉庫的狀態

基本使用

git add 向暫存區(Stage 或 Index)添加文件
如果只是在工作樹中創建文件,該文件不會被記入Git倉庫的版本管理對象中,此時輸入git status,會看到剛剛創建的文件在Untracked files里,要想讓新建的文件成為Git倉庫管理的對象,需要使用git add。暫存區是提交之前的臨時區域。
git commit -m XXXX 將暫存區的內容實際保存到倉庫的歷史記錄中。
git commit -amend 修改上一條提交信息。
git log 查看提交日志
git log XXX 顯示指定文件的日志
git log -p XXX 顯示文件的改動
git log --graph 以圖表形式查看分支
git diff 查看工作樹、暫存區、最新提交之間的差別
git diff HEAD 查看工作樹、最新提交之間的差別

分支相關

git branch -a 顯示分支列表 -a 把遠程分支也顯示出來
git checkout -b XXX **創建并切換分支 **
git branch XXX **創建分支 **
git checkout XXX **切換分支 ** git checkout - 切換到上個分支
git merge 合并分支 git merge --no-ff XXX分支 為了在歷史記錄中明確記錄下本次分支合并,我們需要創建并提交,已經在合并時加上 --no-ff

更改提交的操作

git reset --hard XXXXXXXXXXXXXXXX哈希值 去到某個狀態
git reflog查看當前倉庫的操作日志
git clone http://git.oschina.net/xxx/xxx.git或者 git@git.oschina.net:xxx/xxx.git 克隆一個項目
git remote add origin http://git.oschina.net/xxx/xxx.git或者 git@git.oschina.net:xxx/xxx.git 添加遠程倉庫

git push命令用于將本地分支的更新,推送到遠程主機。它的格式與git pull命令相仿。

$ git push <遠程主機名> <本地分支名>:<遠程分支名>

注意,分支推送順序的寫法是<來源地>:<目的地>,所以git pull是<遠程分支>:<本地分支>,而git push是<本地分支>:<遠程分支>。
如果省略遠程分支名,則表示將本地分支推送與之存在”追蹤關系”的遠程分支(通常兩者同名),如果該遠程分支不存在,則會被新建。
$ git push origin master
上面命令表示,將本地的master分支推送到origin主機的master分支。如果后者不存在,則會被新建。
如果省略本地分支名,則表示刪除指定的遠程分支,因為這等同于推送一個空的本地分支到遠程分支。
$ git push origin :master# 等同于$ git push origin --delete master
上面命令表示刪除origin主機的master分支。
如果當前分支與遠程分支之間存在追蹤關系,則本地分支和遠程分支都可以省略。
$ git push origin
上面命令表示,將當前分支推送到origin主機的對應分支。
如果當前分支只有一個追蹤分支,那么主機名都可以省略。
$ git push
如果當前分支與多個主機存在追蹤關系,則可以使用-u選項指定一個默認主機,這樣后面就可以不加任何參數使用git push。
$ git push -u origin master
上面命令將本地的master分支推送到origin主機,同時指定origin為默認主機,后面就可以不加任何參數使用git push了。
不帶任何參數的git push,默認只推送當前分支,這叫做simple方式。此外,還有一種matching方式,會推送所有有對應的遠程分支的本地分支。Git 2.0版本之前,默認采用matching方法,現在改為默認采用simple方式。如果要修改這個設置,可以采用git config命令。
$ git config --global push.default matching# 或者$ git config --global push.default simple
還有一種情況,就是不管是否存在對應的遠程分支,將本地的所有分支都推送到遠程主機,這時需要使用–all選項。
$ git push --all origin
上面命令表示,將所有本地分支都推送到origin主機。
如果遠程主機的版本比本地版本更新,推送時Git會報錯,要求先在本地做git pull合并差異,然后再推送到遠程主機。這時,如果你一定要推送,可以使用–force選項。
$ git push --force origin
上面命令使用–force選項,結果導致在遠程主機產生一個”非直進式”的合并(non-fast-forward merge)。除非你很確定要這樣做,否則應該盡量避免使用–force選項。
最后,git push不會推送標簽(tag),除非使用–tags選項。
$ git push origin --tags
有時候當遠程xxx分支被刪掉了后,用git branch -a你還可以看到本地還有remote/origin/xxx這個分支,那么你可以使用git fetch -p 這個命令可以幫你同步最新的遠程分支,并刪掉本地被刪了的遠程分支

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容