惠州专业网站建设价格,做网站备案什么意思,红河个旧网站建设,网站流量导入是什么意思文章目录 工作区 暂存区 本地仓库 远程仓库需求#xff1a;已推送到远程仓库#xff0c;想要撤销操作git revert #xff08;添加新的提交来“反做”之前的更改#xff0c;云端会残留上次的提交记录#xff09;git reset#xff08;相当于覆盖上次的提交#xff09;1.--… 文章目录 工作区 暂存区 本地仓库 远程仓库需求已推送到远程仓库想要撤销操作git revert 添加新的提交来“反做”之前的更改云端会残留上次的提交记录git reset相当于覆盖上次的提交1.--soft:2.--mixed (默认选项):3. --hard:注意事项 说明参考 附录git revert的详细说明 工作区 暂存区 本地仓库 远程仓库 需求已推送到远程仓库想要撤销操作
git revert 添加新的提交来“反做”之前的更改云端会残留上次的提交记录
如果你已经将提交推送到了远程仓库并且想要撤销这次提交你可以使用 git revert 命令。
如果你只是要撤销最近的一次提交可以使用 HEAD 指针来引用它
git revert HEAD**请注意使用 git revert 并不会从项目历史中删除任何提交这个命令会创建一个新的提交这个新提交会“反做”之前的提交从而撤销那些更改。这样做的好处是不会改变项目的历史记录因此是协作项目中推荐的做法。
git reset相当于覆盖上次的提交
如果你需要彻底从历史记录中删除提交那么需要考虑使用 git reset 并之后使用 --force 选项与远程仓库同步但这种做法风险较高因为它会改变项目的历史记录。**
1.–soft:
撤销最后一次提交但是保留更改在暂存区。提交信息和更改都会撤销但是更改的内容还在暂存区可以重新提交。
git reset --soft HEAD~12.–mixed (默认选项):
撤销最后一次提交但是保留更改在工作目录。提交信息会被撤销更改的内容会保留在工作目录中需要重新暂存和提交。
git reset --mixed HEAD~1这是默认的 git reset 行为。它会重置 HEAD 和暂存区到指定的提交但不改变工作目录。 相当于 git reset HEAD~1
3. --hard:
撤销最后一次提交并且丢弃所有更改。提交信息和更改都会被永久丢弃工作目录、暂存区和HEAD都会回退到上一个提交的状态。
git reset --hard HEAD~1如果你使用 --hard你将失去最后一次提交的所有更改这是不可逆的。如果你使用 --soft 或 --mixed你将保留更改可以重新提交。
注意事项 如果你的更改已经推送到了远程仓库并且其他人可能已经基于这些更改进行了操作使用 --hard 重置可能会导致问题。 如果你使用 --soft 重置并且想要撤销更改你可以使用 git clean 来清除未提交的更改 git clean -fd这个命令会删除未跟踪的文件和目录-f 表示强制-d 表示删除目录。
说明
git reset 用于移动 HEAD 指针git reset之后云端仍有上次提交的记录所以撤销之后的重新提交需要在git push之后加上 -f 用于强制覆盖上次不用的提交。直接git push会出现问题
git push --force参考
git提交错了别慌直接删除提交记录https://blog.csdn.net/weixin_45334346/article/details/138388941 附录git revert的详细说明
如果你已经将提交推送到了远程仓库并且想要撤销这次提交你可以使用 git revert 命令。这个命令会创建一个新的提交这个新提交会“反做”之前的提交从而撤销那些更改。这样做的好处是不会改变项目的历史记录因此是协作项目中推荐的做法。
以下是使用 git revert 命令的步骤 找到要撤销的提交的哈希值 使用 git log 查看提交历史并找到你想要撤销的提交的哈希值。 执行 revert 操作 使用 git revert 命令加上提交的哈希值来撤销这次提交 git revert [提交哈希值]如果你只是要撤销最近的一次提交可以使用 HEAD 指针来引用它 git revert HEAD解决可能出现的冲突如果有的话 如果撤销过程中出现冲突Git 会停止并让你手动解决这些冲突。解决完冲突后你需要添加这些更改到暂存区并完成 revert 操作 git add [解决冲突的文件]
git revert --continue推送 revert 操作到远程仓库 完成 revert 操作并测试没有问题后将这次 revert 提交推送到远程仓库 git push origin [分支名]请注意使用 git revert 并不会从项目历史中删除任何提交它只是添加一个新的提交来“反做”之前的更改。如果你需要彻底从历史记录中删除提交那么需要考虑使用 git reset 并使用 --force 选项与远程仓库同步但这种做法风险较高因为它会改变项目的历史记录。