Git 常用命令 持續更新

2021-08-20 08:46:39 字數 2411 閱讀 1735

1.git init 初始化

2.git clone 轉殖**到本地

3.git fetch 從遠端倉庫獲取最新的**

4.git pull 把遠端的**更新到本地

5.git add . 那本地的**提交到stage中

6.git commit -m 'comments' 把stage中的修改**提交到本地倉庫

7.git push 把本地的修改**到遠端倉庫

8.git branch -r/-a 檢視遠端所有分支

9.git checkout 切換到某個分支

10.git stash 把暫時不能提交的修改快取到容器中

11.git stash list 檢視快取內容

12.git stash pop 恢復快取到本地的分支

13. git diff 檢視當前新增的內容

14.git diff head 檢視所有沒有commit的內容

15.git reset --hard head 撤銷本地修改

git merge 和 git rebase 的區別

假設我們有如下圖一所示倉庫,該倉庫有master和develop兩個分支,且develop是在(3.added merge.txt file)commit處從master拉出來的分支。

圖一merge

假設現在head在(6.added hello.txt file)處,也就是在master分支最近的一次提交處,此時執行git merge develop, 結果如下圖所示。

圖二工作原理就是:git 會自動根據兩個分支的共同祖先即 (3.added merge.txt file)這個 commit 和兩個分支的最新提交即 (6.added hello.txt file) 和 (5.added test.txt file) 進行乙個三方合併,然後將合併中修改的內容生成乙個新的 commit,即圖二的(7.merge branch 『develop』)。

這是merge的效果,簡單來說就合併兩個分支並生成乙個新的提交。

rebase

那rebase是這麼工作的呢?

假設初始狀態也是圖一所顯示的。兩個分支乙個master,乙個develop,此時head在(6.added hello.txt file)處,現在執行git rebase develop,結果如下圖三所示。

圖三可以看見develop分支分出來分叉不見了,下面來解釋一下它的工作原理:

在執行git rebase develop之前,head在(6.added hello.txt file)處,當執行rebase操作時,git 會從兩個分支的共同祖先 (3.added merge.txt file)開始提取 當前分支(此時是master分支)上的修改,即 (6.added hello.txt file)這個commit,再將 master 分支指向 目標分支的最新提交(此時是develop分支)即(5.added test.txt file) 處,然後將剛剛提取的修改應用到這個最新提交後面。如果提取的修改有多個,那git將依次應用到最新的提交後面,如下兩圖所示,圖四為初始狀態,圖五為執行rebase後的狀態。

圖四

圖五簡單來說,git rebase提取操作有點像git cherry-pick一樣,執行rebase後依次將當前的提交cherry-pick到目標分支上,然後將在原始分支上的已提取的commit刪除。

git merge在檢視上回比較雜亂,而git rebase是一條直線,簡潔

如果存在多個commit時候 並且有多個衝去,git merge只需要解決一次, 而git rebase 需要解決多次

git diff 的命令

匯出最後一次提交修改的檔案 

git archive -o ../updated.zip head $(git diff --name-only head^)

git diff --name-only head     workspace 和 最新的commit進行比較

git diff --name-only head^   workspace 和 最新commit的前一次進行比較

git archive -o 匯出到這個檔案的命令

Git常用命令 持續更新

將本地暫存區的檔案推送到本地庫 git commit m 修改提示 檢視當前 git 狀態 git status從 github 上轉殖專案 git clone將本地庫檔案的修改推送到繫結的 github git push 將遠端庫檔案拉取到本地倉庫 分支 切換分支 git checkout 合併分...

Git常用命令 (持續更新)

生成ssh key ssh keygen t rsa c 設定 git config global user.email git config global user.name 新增remote git remote add git pull rebase使用pull rebase衝突後,修改好衝突...

git常用命令(持續更新中)

git常用命令 持續更新中 本地倉庫操作 git int 初始化本地倉庫 git add 將所有檔案新增到本地倉庫 git commit m 提交檔案 把檔案提交到倉庫,雙引號內是提交注釋 和遠端倉庫建立聯絡 git remote add origin git github.com wangjiax...