日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

git教程——简单总结

發布時間:2025/4/9 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 git教程——简单总结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1 創建版本庫:

  • 初始化一個Git倉庫,使用git init命令。
  • 添加文件到Git倉庫,分兩步:

?(1)使用命令git add <file>,注意,可反復多次使用,添加多個文件;

?(2)使用命令git commit -m <message>,完成。

2 時光穿梭:

  • 要隨時掌握工作區的狀態,使用git status命令。
  • 如果git status告訴你有文件被修改過,用git diff?<file>可以查看修改內容。

2.1 版本回退:

  • HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id。

??? 在Git中,用HEAD表示當前版本, 上一個版本就是HEAD^,上上一個版本就是HEAD^^,當然往上100個版本寫100個^比較容易數不過來,所以寫成HEAD~100。

  • 穿梭前,用git log可以查看提交歷史,以便確定要回退到哪個版本。
  • 要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個版本。

2.2 管理修改:

  • Git是跟蹤修改的,每次修改,如果不用git add到暫存區,那就不會加入到commit中。

2.3 撤銷修改:

  • 場景1:當你改亂了工作區某個文件的內容,想直接丟棄工作區的修改時,用命令git checkout -- file。

git checkout其實是用版本庫里的版本替換工作區的版本,無論工作區是修改還是刪除,都可以“一鍵還原”。

  • 場景2:當你不但改亂了工作區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD <file>,就回到了場景1,第二步按場景1操作。

用命令git reset HEAD <file>可以把暫存區的修改撤銷掉(unstage),重新放回工作區;git reset命令既可以回退版本,也可以把暫存區的修改回退到工作區。

  • 場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫。

2.4 刪除文件:

  • 命令git rm用于刪除一個文件。如果一個文件已經被提交到版本庫,那么你永遠不用擔心誤刪,但是要小心,你只能恢復文件到最新版本,你會丟失最近一次提交后你修改的內容

$ rm test.txt

3 分支管理

查看分支:git branch

創建分支:git branch <name>

切換分支:git checkout <name>

創建+切換分支:git checkout -b <name>

合并某分支到當前分支:git merge <name>

刪除分支:git branch -d <name>

3.1解決沖突

當Git無法自動合并分支時,就必須首先解決沖突。解決沖突后,再提交,合并完成。

解決沖突就是把Git合并失敗的文件手動編輯為我們希望的內容,再提交。

用git log --graph命令可以看到分支合并圖。

3.2分支管理策略

Git分支十分強大,在團隊開發中應該充分應用。

合并分支時,加上--no-ff參數就可以用普通模式合并,合并后的歷史有分支,能看出來曾經做過合并,而fast forward合并就看不出來曾經做過合并。

$ git merge --no-ff -m "merge with no-ff" dev Merge made by the 'recursive' strategy. readme.txt | 1 + 1 file changed, 1 insertion(+)

3.3 Bug分支

修復bug時,我們會通過創建新的bug分支進行修復,然后合并,最后刪除;

當手頭工作沒有完成時,先把工作現場git stash一下,然后去修復bug,修復后,再git stash pop,回到工作現場。

(用git stash list命令查看剛才保存的工作現場,Git把stash內容存在某個地方了,但是需要恢復一下,有兩個辦法:

一是用git stash apply恢復,但是恢復后,stash內容并不刪除,你需要用git stash drop來刪除;

另一種方式是用git stash pop,恢復的同時把stash內容也刪了。)

3.4 Feature分支

開發一個新feature,最好新建一個分支;

如果要丟棄一個沒有被合并過的分支,可以通過git branch -D <name>強行刪除。

3.5 多人協作

多人協作的工作模式通常是這樣:

  • 首先,可以試圖用git push origin <branch-name>推送自己的修改;
  • 如果推送失敗,則因為遠程分支比你的本地更新,需要先用git pull試圖合并;
  • 如果合并有沖突,則解決沖突,并在本地提交;
  • 沒有沖突或者解決掉沖突后,再用git push origin <branch-name>推送就能成功!
  • 如果git pull提示no tracking information,則說明本地分支和遠程分支的鏈接關系沒有創建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>。

    小結:

    • 查看遠程庫信息,使用git remote -v;
    • 本地新建的分支如果不推送到遠程,對其他人就是不可見的;
    • 從本地推送分支,使用git push origin branch-name,如果推送失敗,先用git pull抓取遠程的新提交;
    • 在本地創建和遠程分支對應的分支,使用git checkout -b branch-name origin/branch-name,本地和遠程分支的名稱最好一致;
    • 建立本地分支和遠程分支的關聯,使用git branch --set-upstream branch-name origin/branch-name;
    • 從遠程抓取分支,使用git pull,如果有沖突,要先處理沖突。

    3.6 rebase

    • rebase操作可以把本地未push的分叉提交歷史整理成直線;
    • rebase的目的是使得我們在查看歷史提交的變化時更容易,因為分叉的提交需要三方對比。

    4 標簽管理

    發布一個版本時,我們通常先在版本庫中打一個標簽(tag),這樣,就唯一確定了打標簽時刻的版本。將來無論什么時候,取某個標簽的版本,就是把那個打標簽的時刻的歷史版本取出來。所以,標簽也是版本庫的一個快照。

    Git的標簽雖然是版本庫的快照,但其實它就是指向某個commit的指針(跟分支很像對不對?但是分支可以移動,標簽不能移動),所以,創建和刪除標簽都是瞬間完成的。

    tag就是一個讓人容易記住的有意義的名字,它跟某個commit綁在一起。

    4.1 創建標簽

    • 命令git tag <tagname>用于新建一個標簽,默認為HEAD,也可以指定一個commit id;
    • 命令git tag -a <tagname> -m "blablabla..." 創建帶有說明的標簽,用-a指定標簽名,-m指定說明文字;
    • 命令git tag可以查看所有標簽。
    • 命令git show <tagname>可以查看標簽信息和說明文字。
    $ git tag v1.0? 默認標簽是打在最新提交的commit上 $ git tag v0.9 f52c633??? 也可以找到歷史提交的commit id,然后打上標簽

    4.2 操作標簽

    • 命令git push origin <tagname>可以推送一個本地標簽;
    • 命令git push origin --tags可以推送全部未推送過的本地標簽;
    • 命令git tag -d <tagname>可以刪除一個本地標簽;
    • 命令git push origin :refs/tags/<tagname>可以刪除一個遠程標簽。

    一個本地庫同時關聯到github和碼云

    使用多個遠程庫時,我們要注意,git給遠程庫起的默認名稱是origin,如果有多個遠程庫,我們需要用不同的名稱來標識不同的遠程庫。

    仍然以learngit本地庫為例,我們先刪除已關聯的名為origin的遠程庫:

    git remote rm origin

    然后,先關聯GitHub的遠程庫:

    git remote add github git@github.com:michaelliao/learngit.git

    注意,遠程庫的名稱叫github,不叫origin了。

    接著,再關聯碼云的遠程庫:

    git remote add gitee git@gitee.com:liaoxuefeng/learngit.git

    同樣注意,遠程庫的名稱叫gitee,不叫origin。

    現在,我們用git remote -v查看遠程庫信息,可以看到兩個遠程庫:

    git remote -v gitee??? git@gitee.com:liaoxuefeng/learngit.git (fetch) gitee??? git@gitee.com:liaoxuefeng/learngit.git (push) github??? git@github.com:michaelliao/learngit.git (fetch) github??? git@github.com:michaelliao/learngit.git (push)

    如果要推送到GitHub,使用命令:

    git push github master

    如果要推送到碼云,使用命令:

    git push gitee master

    這樣一來,我們的本地庫就可以同時與多個遠程庫互相同步:

    ?

    ?

    ?

    參考來源:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

    ?

    轉載于:https://www.cnblogs.com/zhenguoli/p/9139482.html

    總結

    以上是生活随笔為你收集整理的git教程——简单总结的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。