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。git
咱们把文件往Git版本库里添加的时候,是分两步执行的:缓存
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区(stage);spa
第二步是用git commit提交更改,实际上就是把暂存区的全部内容提交到当前分支。
当add完之后,再经过git commit 一次性将全部修改提交到分支。这时再git status就会显示nothing to commit (working directory clean) 工做区干净。指针
核心:全部的修改在commit以前,必定要add,否则就不会提交到分支上code
第一次修改 -> 第二次修改 ->git add -> git commit 第一次修改 -> git add -> 第二次修改 -> git add -> git commit //这两种方式,最终获得的效果是同样的
一般来讲,在git commit之前通常都要git,add,不然咱们想要commit的内容实际上并无被commit上去,可是git提供了一个省略git add的办法,那就是git commit -a -m '描述本次commit的内容' ,能够忽略add 直接commit ,-m 参数通常在任何状况下都不省略,由于提交描述是咱们和他人合做的关键blog
git checkout -- filename
命令git checkout -- readme.txt意思就是,把readme.txt文件在工做区的修改所有撤销,这里有两种状况:图片
一种是readme.txt自修改后尚未被放到暂存区,如今,撤销修改就回到和版本库如出一辙的状态;ip
一种是readme.txt已经添加到暂存区后,又做了修改,如今,撤销修改就回到添加到暂存区后的状态。it
总之,就是让这个文件回到最近一次git commit或git add时的状态。ast
场景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用于删除一个文件。若是一个文件已经被提交到版本库,那么你永远不用担忧误删,可是要当心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。