您好,登錄后才能下訂單哦!
分享幾個使用Git本地倉庫的技巧?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
Git是什么?
一個分布式版本控制系統,和SVN類似,但遠比SVN強大的一個版本控制系統 ①Git可以方便的在本地進行版本管理,如同你本地有一個版本管理服務器一樣 我們可以選擇在合適的時間將本地版本推送到統一的版本管理服務器 ②Git每次會提取整個代碼倉庫的完整鏡像,相當于對整個代碼倉庫都進行了一次備份,這樣計時版本服務器除了問題,我們可以直接采用本地倉庫恢復!結合本地版本管理功能,遠程版本管理服務器出問題了,我們依然能繼續寫自己的代碼,當他恢復的時候我們再提交我們的本地版本! Git研發初期是為了更好的管理Linux內核,不過現在已經廣泛應用于各種項目中!
下面看下Git本地倉庫基本操作,具體內容如下所示:
設置姓名和郵箱
設置使用Git時的姓名和郵箱地址。名字須用英文輸入git config --global user.name "chuyaoxin"
git config --global user.email yaoxinchu@126.com
命令運行的結果是在“C:\Users\用戶名”路徑下,產生一個.gitconfig文件,可以用記事本打開。
想更改這些信息時,可以直接編輯這個設置文件。這里設置的姓名和郵箱地址會用在Git的提交日志中。由于在GitHub上公開倉庫時,這里的姓名和郵箱地址也會隨著提交日志一同被公開,所以請不要使用不便公開的隱私信息。
創建倉庫
創建一個新文件夾,比如“TestForGit”
然后右鍵點擊這個文件夾,選擇Git Bash Here
打開后,輸入git init
完成代碼倉庫的建立
輸入ls -al
可以看到目錄下有個.git的文件夾,但這個目錄默認是隱藏的。
提交本地代碼
先用add命令把要提交的內容都加進來,然后commit才是真的去執行提交操作。
第一步,用命令git add告訴Git,把文件添加到倉庫git add readme.txt
第二步,用命令git commit告訴Git,把文件提交到倉庫git commit -m "write a readme file"
.gitignore
.gitignore是Git的忽略配置文件,放在項目根目錄下就行,這樣在提交代碼時就不會跟蹤在.gitignore配置文件列舉的文件。另外,.gitignore文件本身需要被git跟蹤管理,不能被忽略。
git add
用途:可以用來跟蹤新文件,或者添加已被修改的跟蹤的文件到緩存區,或者把合并的沖突文件標記為已解決
git add的原意是更新當前工作目錄樹修改的內容到索引中(也就是緩存中去)
主要針對兩種文件:(1)版本庫沒有跟蹤的文件(2)版本庫已經跟蹤,但是修改了的文件
另外git add會自動忽略.gitignore文件所忽略的文件。
git add .
將文件的修改、文件的新建(注意!不包括被刪除的文件),添加到暫存區
git add .會把所有untrack的文件都加入暫存區,并且會根據.gitignore做過濾
git add *
git add *會忽略.gitignore把任何文件都加入暫存區
git add -u
將文件的修改、文件的刪除(注意!僅監控被add的文件,不包括新文件),添加到暫存區,u表示update
git add -A
將文件的修改,文件的刪除,文件的新建(相當于add .與add -u的合集),添加到暫存區,A表示all其他
可以使用git add -h
命令來查看
$ git add -h usage: git add [<options>] [--] <pathspec>... -n, --dry-run dry run -v, --verbose be verbose -i, --interactive interactive picking -p, --patch select hunks interactively -e, --edit edit current diff and apply -f, --force allow adding otherwise ignored files -u, --update update tracked files --renormalize renormalize EOL of tracked files (implies -u) -N, --intent-to-add record only the fact that the path will be added later -A, --all add changes from all tracked and untracked files --ignore-removal ignore paths removed in the working tree (same as --no-all) --refresh don't add, only refresh the index --ignore-errors just skip files which cannot be added because of errors --ignore-missing check if - even missing - files are ignored in dry run --chmod (+|-)x override the executable bit of the listed files --pathspec-from-file <file> read pathspec from file --pathspec-file-nul with --pathspec-from-file, pathspec elements are separated with NUL character
git commit
git commit -m "write a readme file"
可以在使用了多次git add
之后再使用git commit
來提交。
在git commit命令中,-m后面輸入的是本次提交的說明,可以輸入任意內容,但最好是有意義的,這樣就能從歷史記錄里方便地找到改動記錄。
執行成功后,從圖中可以看出,一個文件被改動,插入了6行內容。
git status
git status
可以使用git status
命令查看是否還有文件未提交
上圖說明當前文件都已正常提交。
如果我對上傳的文件進行修改,但是卻不提交會如何?
會報出如上所示的錯誤!modified: readme.txt no changes added to commit
字面意思:readme.txt被修改,提交沒有變化
git diff
git diff readme.txt
git status
可以讓我們知道有沒有正常提交,比如上面那個例子,但如果要查看文件到底修改了什么內容,可以使用git diff 文件名
命令
這條命令將我對這個文件的修改記錄顯示了出來
查看提交記錄git log
使用git log即可查看歷史提交信息
從這張圖也可以看出之前git commit -m "write a readme file"
中,-m部分的作用,這個和編程時寫注釋是一樣的,可以不寫,但是寫的話方便以后的工作。
還有要注意的地方是輸出的結果,
顯然我這是提交了兩次,以第一次的結果為例,
commit 418ee0fc27d78a71f5869451b5a1599cc028b0ca (HEAD -> master)
Author: chuyaoxin yaoxinchu@126.com
Date: Tue Aug 4 19:48:59 2020 +0800
write a readme file
對應的含義分別是
此次提交對應的版本號
提交人:姓名 郵箱
提交的時間
提交版本修改的內容:就是我們git commit -m “xxx”
里的xxx
撤銷未提交的修改
如果對文件進行了錯誤的修改,且已經Ctrl+S保存,但還沒有提交,想要撤銷之前的修改可以使用checkout
命令
不僅未提交,而且沒有add
如果是這種情況,只需要一句git checkout 修改的文件名
即可
例如,git checkout readme.txt
此時,再打開readme.txt,我對此文件的第二次修改被取消掉了
已經add,但還沒有提交
如果我們已經add了的話,那么直接checkout是沒任何作用的,我們要先取消添加才可以撤回提交git reset HEAD readme.txt
git checkout readme.txt
版本回退git reset
如果我們已經提交,但想退回到之前的版本,可以使用git reset
命令
比如我先在readme.txt中添加了一行,然后git add readme.txt
,git commit -m "add the third step"
,添加并提交到倉庫
完成之后,使用git log
檢查提交記錄。
PS:通過這張圖也能看出,最新的版本號顯示在最上方git reset --hard HEAD
在git中,HEAD表示當前版本,HEAD表示上一個版本,HEAD^表示上上個版本
退回到上一個版本需要依次輸入以下指令git reset --hard HEAD
git reset --hard HEAD^
執行結果如下圖所示:
再輸入git log
查看,此時的版本號已經發生了變化,最新修改的那個版本號沒有顯示出來了
git reset --hard 版本號
這條命令可以讓我們將當前版本更改為存在過的任意一個版本
同時仔細觀察這張圖,
可以很容易的猜到,其實版本號只要輸入前七位就可以了
所以我們之前的回退指令可以用這條來替代,git reset --hard 418ee0f
git reflog
如果你版本回退之后發現,還是最新的那個版本好一點,但此時通過git log
已經找不到那個版本號了,
可以使用git reflog
顯然,版本回退之前的最新版本號為14a5f92
然后使用git reset --hard 14a5f92
打開readme.txt,因為版本回退而去掉的修改又回來了
關于分享幾個使用Git本地倉庫的技巧問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。