浅谈git撤销回退命令相关用法
来源:互联网 发布:淘宝访问深度怎么算 编辑:程序博客网 时间:2024/06/05 12:50
初来公司实习,每次改完代码后都需要用代码管理工具git提交到代码库。由于刚开始对 git 并不熟悉,只会简单的 commit,push 指令,一旦提交出了问题需要撤销回退的话就不知道该怎么办了。经过一段时间的研究,总算是把里面相关原理搞懂了,遇到git提交出现问题,现在自己也能想办法解决而不至于手足无措了。下面就说说我对git撤销回退这块相关的理解。
git reset
首先,我们要弄清以下三条命令的区别:
git reset –hard
git reset –soft
git reset
工作区,暂存区,本地仓库,远程仓库的概念我在这里就不介绍了。这是git最为基础的概念,可自行百度。下面说说这三条 git reset 指令的区别:
git reset –hard: 重置工作区,暂存区,本地仓库的所有文件到某一节点。例如 git reset –hard HEAD^ 表示工作区,暂存区,本地仓库的所有文件全部回退到上一个节点,也就是说你从上一个节点到这个节点之间所做的修改全部被撤销了。当然如果要回到特定的一个节点可以用 git reset –hard commitId 。通过指定要回到的节点值来回到对应的节点。
git reset –soft:只重置本地仓库的文件,工作区和暂存区的文件不变。
git reset 等同于 git reset –mixed,只重置本地仓库和暂存区文件,工作区文件不变。
当我们提交完并push代码到远程仓库后,发现代码有问题,想重新提交,首先在gerrit上abandon掉自己刚才上传的代码,接着,用git reset HEAD^或者git reset –soft HEAD^回到上一个节点(git reset HEAD^后,使用git add .就相当于git reset –soft),不要用git reset –hard。因为这会把你本地工作区修改的全部撤销,这样你之前的修改就全没了。虽然也有办法再找回来,只要找到那次提交的commitId就可以了,下面会介绍。
另外,我们还可以用git reset file 来使一个已经添加到暂存区的file文件重新返回到工作区。
git log
我们通过git log就可以查看到每次提交的 commitId 了,如果嫌 git log 显示的信息过多,可以使用 git log –pretty=oneline 让每次提交的关键信息在一行显示。但是如果使用了 git reset –hard,那么使用 git log 只能看到你重置点之前的提交 commitId,无法看到重置点之后的提交 commitId,要想找到重置点之后的 commitId 可以用git reflog。
git checkout
git checkout有两个作用,如果后面接的是文件名的话,如 git checkout file 可以将一个工作区的文件撤销其修改。如果后面接的是分支名的话,如 git checkout b表示的是切换到b分支。对于工作区新建立的文件,用 git clean -df 可将其移除工作区。
- 浅谈git撤销回退命令相关用法
- git 所有撤销、回退命令
- git撤销回退版本
- git 版本回退,撤销修改
- 辛星浅析git中的代码撤销与回退
- git撤销本地修改与回退版本
- git 命令 撤销
- vim 撤销 回退操作
- Vim 撤销 回退 操作
- sourceTree回退撤销commit
- Git相关命令及用法
- Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突
- Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突
- Git用法之撤销操作
- Git用法之撤销操作
- git在未提交commit之前,撤销回退所有操作
- Git-撤销(回退)已经add,commit或push的提交
- jbpm4 回退、会签、撤销、自由流
- buffer的slice()方法返回的新buffer和原buffer引用的是同一个对象!!!修改千万要注意!
- TortoiseGit 对 github 版本库的管理
- angular-scope依赖关键字注入-解决办法
- 【Unity&NGUI】创建NGUI的Scroll View的一些问题以及拓展
- Leetcode两道小题目python试水
- 浅谈git撤销回退命令相关用法
- 银行ATM分析类类图文档
- 内存和硬盘有什么区别?(2017-4-26)
- 斗地主AI算法——第七章の被动出牌(1)
- jquery判断复选框checkbox及改变checkbox状态
- Coreseek中文检索引擎
- PHP学习笔记——可变个数参数的函数;
- 【一步一个脚印】Tomcat+MySQL为自己的APP打造服务器(4)完结篇
- Angular入门篇1-2