git命令行学习笔记

1、新建、删除仓库操做

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

2、版本回退

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

回退的关键是要找到版本号,若是一不当心关掉了电脑,经过git log命令没法打印出以前的操做记录,可是能够经过
git reflog  //显示出操做记录,从中找到版本号,而后再回退。
若是回退到了以前较旧的版本,又想回到较新的版本,也仍然能够用git reset --hard 版本号 实现,
全部版本穿梭的关键就是准备定位版本号。

3、工做区和缓存区的概念

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

clipboard.png

咱们把文件往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  //这两种方式,最终获得的效果是同样的

clipboard.png

一般来讲,在git commit之前通常都要git,add,不然咱们想要commit的内容实际上并无被commit上去,可是git提供了一个省略git add的办法,那就是git commit -a -m '描述本次commit的内容' ,能够忽略add 直接commit ,-m 参数通常在任何状况下都不省略,由于提交描述是咱们和他人合做的关键blog

4、撤销修改

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:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

5、删除和恢复

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

git checkout实际上是用版本库里的版本替换工做区的版本,不管工做区是修改仍是删除,均可以“一键还原”。
命令git rm用于删除一个文件。若是一个文件已经被提交到版本库,那么你永远不用担忧误删,可是要当心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
图片描述

相关文章
相关标签/搜索