目录
一、Git状态查看
git status 命令
二、修改内容查看
命令git diff 名>
三、版本回退
命令git log
命令git log --pretty=oneline
命令git reset --hard HEAD^
命令git reset --hard 9178f(指定版本号前几位)
命令git relog
四、工作区和暂存区
五、管理修改
命令 git diff HEAD -- readme.txt(文件名)
六、撤销修改
命令 git checkout --readme.txt(文件名)
命令 git restore readme.txt(文件名)
命令 git reset HEAD readme.txt(文件名)
命令 git restore --staged readme.txt(文件名)
七、删除文件
命令 rm test.txt(文件名)
命令git rm test.txt(文件名)
命令 git checkout --test.txt(文件名)
$ git status #掌握仓库当前状态
On branch master
Changes not staged for commit:
(use "git add ..." to update what will be committed)
(use "git restore ..." to discard changes in working directory)
modified: readme.txt
no changes added to commit (use "git add" and/or "git commit -a")
时刻掌握版本库当前的状态,上面输出表示,readme.txt被修改但未提交修改。
$ git diff readme.txt #查看修改内容
diff --git a/readme.txt b/readme.txt
index d8036c1..013b5bc 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,2 +1,2 @@
-Git is a version control system.
+Git is a distributed version control system.
Git is free software.
\ No newline at end of file
查看文件具体修改了什么内容。可以看出文件第一行添加了distributed单词。
查看完文件的状态,修改的内容,重复之前的命令git add 文件名 和命令git' commit 文件名将文件上传至版本库。
$ git log #查看历史记录
commit 9178f48947263ebeb3535bb46ae14f570b3849f2 (HEAD -> master)
Author: Limi <85077****@qq.com>
Date: Sat Mar 4 17:10:37 2023 +0800
append GPL
commit 84cca8867e7496c3a79f82f3f4dfe77c0295b6bf
Author: Limi <85077****@qq.com>
Date: Sat Mar 4 17:06:14 2023 +0800
add distributed
commit bdcbe49238aaa00f07e7fc14449e96ac7812f511
Author: Limi <85077****@qq.com>
Date: Thu Mar 2 21:21:30 2023 +0800
wrote a readme file
显示从最近到最远的提交日志。
$ git log --pretty=oneline
9178f48947263ebeb3535bb46ae14f570b3849f2 (HEAD -> master) append GPL
84cca8867e7496c3a79f82f3f4dfe77c0295b6bf add distributed
bdcbe49238aaa00f07e7fc14449e96ac7812f511 wrote a readme file
简化输出的日志信息,由多行变为一行。
注意:看到的一大串类似9178f..
的是commit id
(版本号),且版本号与我的不会相同。
$ git reset --hard HEAD^ #回退至上一版本
HEAD is now at 84cca88 add distributed
将当前版本回退至上一个版本。其中HEAD表示当前版本,也就是最新提交的9178f...,上一版本就是HEAD^,上上一个版本就是HEAD^^,往上100个版本,写成HEAD~100。
$ git reset --hard 9178f #去往未来版本
HEAD is now at 9178f48 append GPL
在使用版本回退后,又想要回到回退前的版本,可以指定回到未来的某个版本,版本号没必要写全,前几位就可以了,Git会自动去找。
原理:Git在内部有个指向当前版本的HEAD
指针,当你回退版本的时候,Git仅仅是把HEAD从指向append GPL,改为指向add distributed,
然后顺便把工作区的文件更新了。
$ git reflog #记录每一次的命令
9178f48 (HEAD -> master) HEAD@{0}: reset: moving to 9178f
84cca88 HEAD@{1}: reset: moving to HEAD^
9178f48 (HEAD -> master) HEAD@{2}: commit: append GPL
84cca88 HEAD@{3}: commit: add distributed
bdcbe49 HEAD@{4}: commit (initial): wrote a readme file
记录每一次的命令,可以找到任何版本的commit id。当回退到了之前某个版本,关掉了电脑,第二天早上就后悔了,想恢复到新版本时,可以说使用该命令找到某版本的版本号前几位。
工作区:就是电脑里能看的的目录,例如learngit文件夹。
版本库:工作区有一个隐藏目录.git
,这个不算工作区,而是Git的版本库。
版本库中含有一个stage(或者叫index)的暂存区和自动创建的分支master。
$ git diff HEAD -- readme.txt #查看工作区和版本库里面的最新版本的区别
diff --git a/readme.txt b/readme.txt
index db28b2c..a9c5755 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,4 +1,4 @@
Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
-Git tracks changes.
\ No newline at end of file
+Git tracks changes of files.
可以查看工作区和版本库里面最新版本的内容区别.。
$ git checkout -- readme.txt #撤销还在工作区的文件修改
把文件在工作区的修改全部撤销。(对文件中内容的操作,无法对添加文件、删除文件起作用)
$ git restore readme.txt
丢弃工作区的修改(不包括对文件自身的操作,如添加文件、删除文件)
$ git reset HEAD readme.txt #暂存区的修改回退到工作区
Unstaged changes after reset:
M readme.txt
把暂存区的修改回退到工作区,会将暂存区的内容和本地已提交的内容全部恢复到未暂存的状态,不影响原来本地文件(相当于撤销git add 操作,不影响上一次commit后对本地文件的修改) (包括对文件的操作,如添加文件、删除文件)
$ git restore --staged readme.txt
将暂存区的修改重新放回工作区(包括对文件自身的操作,如添加文件、删除文件)
$ rm test.txt #在工作区删除文件
删除文件管理器(工作区)的文件,未删除版本库的文件,会存在工作区与版本库内容不统一。
也可以自己手动删除,结果一致。
$ git rm test.txt #删除版本区文件
rm 'test.txt'
$ git commit -m "remove test.txt" #将删除版本库文件的修改传送至分支保存
[master 53e89d7] remove test.txt
1 file changed, 0 insertions(+), 0 deletions(-)
delete mode 100644 test.txt
删除版本库中的文件,需要与git commit合用,将修改后的情况提交至分支保存。
$ git checkout -- test.txt #可以恢复工作区内误删但是版本库还有的文件
版本库里还有但工作区误删,用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
与之前的撤销修改中的命令相同,因此该命令的作用为:
丢弃工作区的修改,并用最近一次的版本库还原到当前工作区。
注意:未添加到版本库就被删除的文件无法恢复。且由于恢复到最新一版的内容,导致最新一版后修改的内容将丢失。