一、新建、删除仓库操作

git init         //新建一个空仓库,仓库就是当前目录
git init [project-name]   //在当前目录新建一个peoject-name仓库,相当于在里面新建了一个文件夹

二、版本回退

git log                  //显示操作历史记录
git log --pretty=oneline //用一行来显示操作历史记录
git reset --hard head^   //回退到上一个版本
git reset --hard 版本号   //回退到指定版本

回退的关键是要找到版本号,如果一不小心关掉了电脑,通过git log命令无法打印出之前的操作记录,但是可以通过
git reflog  //显示出操作记录,从中找到版本号,然后再回退。
如果回退到了之前较旧的版本,又想回到较新的版本,也仍然可以用git reset --hard 版本号 实现,
所有版本穿梭的关键就是准备定位版本号。

三、工作区和缓存区的概念

工作区就是电脑里能看到的目录,工作区里有一个隐藏文件夹.git,这是git的版本库。
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

clipboard.png

我们把文件往Git版本库里添加的时候,是分两步执行的:

第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区(stage);

第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
当add完以后,再通过git commit 一次性将所有修改提交到分支。这时再git status就会显示nothing to commit (working directory clean) 工作区干净。

核心:所有的修改在commit之前,一定要add,不然就不会提交到分支上

第一次修改 ->  第二次修改 ->git add -> git commit
第一次修改 -> git add -> 第二次修改 -> git add -> git commit  //这两种方式,最终得到的效果是一样的

clipboard.png

通常来说,在git commit以前一般都要git,add,否则我们想要commit的内容实际上并没有被commit上去,但是git提供了一个省略git add的办法,那就是git commit -a -m '描述本次commit的内容' ,可以忽略add 直接commit ,-m 参数一般在任何情况下都不省略,因为提交描述是我们和他人合作的关键

四、撤销修改

git checkout -- filename

命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:

一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;

一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。

总之,就是让这个文件回到最近一次git commit或git add时的状态。

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。

场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

五、删除和恢复

如果你删除了一个文件1.txt
$ git status //git知道文件已经被你删除了,并会提示你,提供了以下两种选择
$ git checkout -- 1.txt  //如果你是误删,通过这条指令可以将文件恢复到工作区
$ rm 1.txt               //如果你确定要删除,通过这条指令可以将文件从git版本库中删除

git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
图片描述


changes
275 声望1 粉丝