【Git&GitHub - 9】:Git撤销修改

简介: 【Git&GitHub - 9】:Git撤销修改

Git撤销修改


Git撤销工作区的修改


  • 在本地仓库Newproject的工作区,我们修改demo.txt文件


4de05ca60e8d487aa311fc920946e1ff.png


指令:git restore 文件名


git restore指令使得在工作空间被修改的文件撤销更改(内容恢复到没修改之前的状态)

f0907d841e4c4d4ea46c21f36c96953e.png


  • 再次查看文件内容,发现文件内容恢复到没修改之前的状态

7e298901b3f745a9aa4f04cd1a038777.png


指令:git checkout -- 文件名


  • 在本地仓库Newproject的工作区,我们又修改demo.txt文件


git checkout -- 文件名指令表示如果暂存区有该文件那么从暂存区还原文件、如果没有则从版本库还原文件

9f7419eb74e846189252c783891e8e97.png


Git撤销暂存区的修改


1、先使用git restore --staged 文件名将文件从暂存区撤出到工作区


2、再使用git restore 文件名指令使得在工作空间被修改的文件撤销更改


  • 在本地仓库Newproject的工作区,我们又修改demo.txt文件

8123ae66e5894f438f5370ae03c18f4c.png

86491c9d39b742d393957abd86dd6309.png

82b99ebd94d94655b15a06ac8fa6f0af.png



Git撤销本地提交的修改


指令:git reset --hard 版本id


使用git reset --hard版本id指定回退到某个版本


  • 先查看日志

bd11bde5ddfb41dfa7b8a12c72680e37.png

  • 回退到 “我写入了一个A” 的版本

e946f831e8db466ba27abf065b0f6d1c.png




Git撤销远程提交的修改


  • 先做两个修改并分别提交到本地库

b82d1507ab004254847a8cb6d7724f40.png


  • 使用git push origin main推送本地仓库到远程仓库

4cbe8e1db414437ea065cb340dacacbf.png


  • 我们发现远程仓库已经有了修改的提交记录!

aefed33a82a3444183827cd4a4d6caf9.png


  1. .先使用git reset --hard版本id指定回退到上个版本


2.再使用git push -f origin main推送本地仓库到远程仓库


788a557f98194348ad48231abe63e290.png



  • 我们发现远程仓库已之前修改的提交记录已经没有了

6e95f73754bc4873a78109aafab3a197.png


注意:git push -f这个命令形式在实际开发中应该慎用、容易造成一些问题!

相关文章
|
24天前
|
开发工具 git 开发者
掌握版本控制的艺术:Git 与 GitHub 的高效使用指南
在软件开发中,版本控制对于代码管理和团队协作至关重要。本文详细介绍了 Git 的核心概念与命令,包括初始化、创建仓库、文件跟踪、分支管理和远程仓库操作。同时,探讨了如何利用 GitHub 进行项目组织、代码审查及自动化工作流。通过遵循最佳实践,如频繁提交、清晰的信息记录和合理使用分支,开发者可以提升工作效率和团队协作能力,确保项目的持续成功。
|
20天前
|
Shell 网络安全 开发工具
Git,GitHub,Gitee&IDEA集成Git
Git提交项目到GitHub简洁版、版本控制、安装、常用命令、分支、团队协作机制、Github、Gitee远程仓库、IDEA集成Git、IDEA集成Github、IDEA集成Gitee
Git,GitHub,Gitee&IDEA集成Git
|
6天前
|
Shell 网络安全 开发工具
fatal: unable to access 'https://github.com/wolfcw/libfaketime.git/': Encountered end of file
fatal: unable to access 'https://github.com/wolfcw/libfaketime.git/': Encountered end of file
|
3月前
|
网络安全 开发工具 git
【git】解决git报错:ssh:connect to host github.com port 22: Connection timed out 亲测有效
【git】解决git报错:ssh:connect to host github.com port 22: Connection timed out 亲测有效
593 1
|
4月前
|
Shell 测试技术 网络安全
【GIT】如何在GitHub上向一个开源项目贡献代码?
【GIT】如何在GitHub上向一个开源项目贡献代码?
51 5
|
4月前
|
开发工具 git
【已解决】error: failed to push some refs to ‘git@github.com:BATdalao/Github-green.git‘
【已解决】error: failed to push some refs to ‘git@github.com:BATdalao/Github-green.git‘
66 1
|
3月前
|
网络安全 开发工具 git
使用git克隆仓库报错:Warning: Permanently added‘github.com’ to the .....(ssh )
所以,你可以安全地忽略这个警告,它不会影响到你使用git克隆仓库。如果你已经成功克隆了仓库,那么一切都在正常工作。如果你在克隆过程中遇到其他问题,那可能需要查看具体的错误信息来解决。
52 0
|
4月前
|
开发工具 git
出现“error: failed to push some refs to ‘https://github.com/****.git‘”,如何解决问题
出现“error: failed to push some refs to ‘https://github.com/****.git‘”,如何解决问题
226 1
|
4月前
|
开发工具 git
idea中git替换,推送到新的github或者gitlab上面
idea中git替换,推送到新的github或者gitlab上面
314 2
|
4月前
|
Shell 开发工具 git
如何使用git上传代码github仓库
如何使用git上传代码github仓库
下一篇
无影云桌面