git 常用命令
- 撤销刚刚的commit,使文件改动恢复到暂存区
git reset --soft HEAD^
git-数据恢复
git reflog-查看引用日志
reflog = Reference log,表示引用日志。当本地仓库中的引用发生移动时,reflog 都会记录下这个移动的行为,跟部移动记录仪差不多。
仓库中的『引用』包括HEAD指针和分支指针
git reflog <ref> // 其中ref默认HEAD指针,可以通过替换ref来查看其他引用的日志
//查看 master 分支指针的移动记录
git reflog master
//查看 feature/test 分支指针的移动记录
git reflog feature/test
执行reflog后打印的内容如下:
(1)41b9778 这条数据中。41b9778是你执行commit的SHA1值。(特别注意,它是移动后的 commit–?)
(2)HEAD@{2} 标识了HEAD指针在2个移动之前指向的内容(从当前往回数第3个操作),也即41b9778 )
(3)"commit"标识了造成该移动的原因(即是进行了commit操作)
(4)"创建11.txt文件"标识了操作的内容,commit 操作对应的就是 commit message。
reflog的用处
- 恢复reset --hard
找到 reset 操作前的 commit
终端linux命令+git
history
查看终端中输入的所有命令的历史记录。
首先确认本地代码都已经在icode上提交
- 切换到master分支上
- git diff > tmp.patch (新建一个tmp.patch文件)
- git checkout tools/util.js(待整理)
- rm output.tar.gz (待整理,移除不需要的文件)
- git merge dbg_self_advertSa --squash(将此次开发分支合并到master分支上,待整理squash是什么?)
- git diff HEAD – .(待整理)
- history | grep commit(待整理)
- git pull 拉取前不久何如的代码并处理冲突
- git commit -m (再提交一遍)