Git常用命令总结

git config

git config --global user.name "Your Name"
git config --global user.email "email@example.com"

git status

假设未执行 add 操作

git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

    modified:   file1

no changes added to commit (use "git add" and/or "git commit -a")

如果有 git add 追踪的文件,但是未 commit

git status
等待commit
On branch banana
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

    modified:   file1
    modified:   file2

git reset

先来看 usage:

usage: git reset [--mixed | --soft | --hard | --merge | --keep] [-q] [<commit>]
   or: git reset [-q] <tree-ish> [--] <paths>...
   or: git reset --patch [<tree-ish>] [--] [<paths>...]

    -q, --quiet           be quiet, only report errors
    --mixed               reset HEAD and index
    --soft                reset only HEAD
    --hard                reset HEAD, index and working tree
    --merge               reset HEAD, index and working tree
    --keep                reset HEAD but keep local changes
    -p, --patch           select hunks interactively
    -N, --intent-to-add   record only the fact that removed paths will be added later

举个例子,说明常用的一些参考操作,具体的对比请看后续文章

commit的文件,可是使用 git reset --soft HEAD^ 来恢复到某一个commit

git reset --soft HEAD^
git status #Changes to be committed,use "git reset HEAD <file>..." to unstage
git reset -q file #Changes not staged for commit
git reset --hard # 此时会重设working tree

如果想要恢复回退之前的版本,在git log上是无法查到的,此时可以使用 git reflog

git reflog

继续执行

git reset --hard <HEAD>
  • 注: 默认的git reset,仅仅会删除 index的内容
  • 注: reflog 记录所有HEAD的历史,也就是说当使用 reset,checkout等操作的时候,这些操作会被记录在reflog中。
  • 注: git reset --hard 未指定版本号时,执行最近一次 commit 的状态,按照那次 commit 重设 HEAD, index and working tree 。这就是意味着如果在修改之后没有提交commit,直接使用 git reset ——hard,修改会丢失

reset,reflog,log这三个命令搭配起来,做项目,联调的时候是件很爽的事情

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Git常用命令总结 git init 在本地新建一个repo,进入一个项目目录,执行git init,会初始化一个...
    曾基锟阅读 259评论 0 0
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,648评论 1 26
  • git init 图例中首先创建了一个空的文件夹gitDemo,进入该文件夹,运行git init命令,提示创建了...
    我是那只喵阅读 292评论 0 1
  • 基础命令 用户设置 初始化仓库 把文件添加到仓库 把文件提交到仓库 添加文件到Git仓库 分两步: 第一步,使用命...
    前端渣渣阅读 1,467评论 0 20
  • m曾经辉煌的他因贪腐入狱,老婆为了孩子递上离婚协议,他毅然放弃一切签下离婚书。本来那个家里就没有自己什么,也谈不上...
    张译刈阅读 249评论 0 0