git取消commit的方法:1、利用“git rm”命令撤销;2、利用“git reset”命令撤销;3、利用“git rebase”命令撤销;4、利用“git revert”命令撤销。
本教程操作环境:Windows7系统、Git2.30.0版、Dell G3电脑。
有时我们提交了错误的代码,需要撤销某次的 commit 记录,下面介绍几种方法:
一、删除文件
如果需要删除的 commit 是一个或多个文件,可以进行以下操作。
1、被提交到仓库的某个文件需要删除,可以使用 git rm
命令:
git rm <file> // 从工作区和暂存区删除某个文件 git commit -m "" // 再次提交到仓库
2、如果只想从暂存区删除文件,本地工作区不做出改变,可以:
git rm --cached <file>
3、如果在工作区不小心删错了某个文件,可以用 git checkout
将暂存区的文件覆盖工作区的文件,从而把误删的文件恢复:
git checkout -- <file>
4、用 git rm
删除文件,同时还会将这个删除操作记录下来;
用 rm
删除文件,删除的仅仅是本地物理文件,没有将其从 git 的记录中剔除。
5、git add
和 git rm
有相似的功能,
但 git add
仅能记录添加、改动的动作,删除的动作需靠 git rm
来完成。
二、GitHub 撤销某次 commit
如果需要删除的不只是某个文件,而是交错的代码,那么有以下三种方法可以删除 commit 。
1、git reset
-
git reset
:回滚到某次提交。 -
git reset --soft
:此次提交之后的修改会被退回到暂存区。 -
git reset --hard
:此次提交之后的修改不做任何保留,git status
查看工作区是没有记录的。
1)回滚代码
如果需要删除的 commit 是最新的,那么可以通过 git reset
命令将代码回滚到之前某次提交的状态,但一定要将现有的代码做好备份,否则回滚之后这些变动都会消失。具体操作如下:
git log // 查询要回滚的 commit_id git reset --hard commit_id // HEAD 就会指向此次的提交记录 git push origin HEAD --force // 强制推送到远端
2)误删恢复
如果回滚代码之后发现复制错了 commit_id,或者误删了某次 commit 记录,也可以通过下方代码恢复:
git relog // 复制要恢复操作的前面的 hash 值 git reset --hard hash // 将 hash 换成要恢复的历史记录的 hash 值
- 注意:删除中间某次提交时最好不要用
git reset
回退远程库,因为之后其他人提交代码时用git pull
也会把自己的本地仓库回退到之前的版本,容易出现差错进而增加不必要的工作量。
2、git rebase
-
git rebase
:当两个分支不在一条线上,需要执行 merge 操作时使用该命令。
1)撤销提交
如果中间的某次 commit 需要删除,可以通过 git rebase
命令实现,方法如下:
git log // 查找要删除的前一次提交的 commit_id git rebase -i commit_id // 将 commit_id 替换成复制的值 进入 Vim 编辑模式,将要删除的 commit 前面的 `pick` 改成 `drop` 保存并退出 Vim
这样就完成了。
2)解决冲突
该命令执行时极有可能出现 reabase 冲突,可以通过以下方法解决:
git diff // 查看冲突内容 // 手动解决冲突(冲突位置已在文件中标明) git add <file> 或 git add -A // 添加 git rebase --continue // 继续 rebase // 若还在 rebase 状态,则重复 2、3、4,直至 rebase 完成出现 applying 字样 git push
3、git revert
-
git revert
:放弃某次提交。git revert
之前的提交仍会保留在 git log 中,而此次撤销会做为一次新的提交。 -
git revert -m
:用于对 merge 节点的操作,-m 指定具体某个提交点。
1)撤销提交
要撤销中间某次提交时,使用 git revert
也是一个很好的选择:
git log // 查找需要撤销的 commit_id git revert commit_id // 撤销这次提交
2)撤销 merge 节点提交
如果这次提交是 merge 节点的话,则需要加上 -m
指令:
git revert commit_id -m 1 // 第一个提交点 // 手动解决冲突 git add -A git commit -m "" git revert commit_id -m 2 // 第二个提交点 // 重复 2,3,4 git push
推荐学习:《Git教程》
以上是git怎么取消commit的详细内容。更多信息请关注PHP中文网其他相关文章!

GitHub是一个基于Git的版本控制系统托管平台,提供版本控制、协作开发和社区交流功能。使用GitHub可以提高开发效率和代码质量。

Git和GitHub是不同的工具:Git是用于版本控制的软件,GitHub是基于Git的在线平台。1.Git允许你跟踪文件变化和协同开发。2.GitHub提供代码托管和协作工具,增强团队开发效率。

GitHub的核心功能包括版本控制、分支管理、代码审查、问题跟踪和项目管理。1.版本控制与分支管理基于Git,允许追踪代码变更和实验性开发。2.代码审查通过PullRequest实现,提升代码质量和团队协作。3.问题跟踪与项目管理通过Issues和项目管理板进行,提高项目透明度和可追踪性。

GitHub是提升软件开发效率和质量的强大工具。1)版本控制:通过Git管理代码变更。2)PullRequests:进行代码审查,提高代码质量。3)Issues:跟踪bug和项目进度。4)GitHubActions:自动化构建、测试和部署流程。

Git是版本控制系统,GitHub是基于Git的代码托管平台。Git用于管理代码版本,支持本地操作;GitHub提供在线协作工具,如Issue跟踪和PullRequest。

Git是一个开源的分布式版本控制系统,帮助开发者跟踪文件变化、协同工作和管理代码版本。它的核心功能包括:1)记录代码修改,2)回退到之前版本,3)协同开发,4)创建和管理分支进行并行开发。

Git和GitHub不是同一回事。Git是版本控制系统,GitHub是基于Git的代码托管平台。Git用于管理代码版本,GitHub提供在线协作环境。

使用GitHub管理HTML项目的原因是它提供了版本控制、协作开发和展示作品的平台。具体步骤包括:1.创建并初始化Git仓库,2.添加和提交HTML文件,3.推送到GitHub,4.使用GitHubPages部署网页,5.利用GitHubActions自动化构建和部署。此外,GitHub还支持代码审查、Issue和PullRequest功能,帮助优化和协作开发HTML项目。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

Atom编辑器mac版下载
最流行的的开源编辑器

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

禅工作室 13.0.1
功能强大的PHP集成开发环境

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中