本地不小心【git checkout .】后的抢救措施!

PyCharm救星:误删代码的恢复技巧
在一次不慎操作中,作者误将两周的未保存代码从错误的文件夹中删除,引发了一场代码丢失危机。幸运的是,PyCharm内置的历史记录功能成为了救命稻草,帮助找回了所有丢失的代码。本文详细介绍了如何利用PyCharm的这一强大功能进行代码恢复的过程。

背景

今天不小心进错文件夹,把一堆没保存的代码checkout掉了,当时吓得我汗都出来了。。。。。。那可是攒了两周的代码。

处理

  1. git没有后悔药了;
  2. 好在Pycharm有历史记录功能,找了回来,感谢jetbrains
    操作如下:
    在项目的文件夹上右键
    在这里插入图片描述
`git checkout` 和 `git checkout .` 是 Git 中用于切换分支或恢复工作目录文件的命令,但它们的作用范围同。下面详细解释它们的区别: --- ### 1. `git checkout <branch-name>`: 这个命令用于**切换分支**。例如: ```bash git checkout dev ``` 这会将当前工作目录切换到名为 `dev` 的分支上。Git 会更新工作目录中的文件以反映该分支的最新提交。 #### 适用场景: - 切换到另一个分支进行开发。 - 创建并切换到新分支(配合 `-b` 参数): ```bash git checkout -b new-feature ``` --- ### 2. `git checkout .`: 这个命令用于**丢弃工作目录中所有未提交的更改**(即撤销对工作目录中已跟踪文件的修改),它会影响暂存区以外的文件(如未跟踪文件)。 ```bash git checkout . ``` 等价于: ```bash git checkout -- . ``` 这将恢复当前目录及其子目录中所有已修改的文件到最近一次提交的状态,**所有未提交的更改都会被删除**。 #### 适用场景: - 想要快速撤销所有本地修改。 - 在切换分支前清理工作目录。 --- ### 示例代码(演示 `git checkout .` 的效果): 假设你有一个 Java 文件 `Main.java`: ```java public class Main { public static void main(String[] args) { System.out.println("Hello, Git!"); } } ``` 你修改了它: ```java public class Main { public static void main(String[] args) { System.out.println("Hello, World!"); } } ``` 然后执行: ```bash git checkout . ``` 此时,`Main.java` 的内容将恢复为 `"Hello, Git!"`。 --- ### 总结区别: | 命令 | 功能描述 | 是否切换分支 | 是否恢复文件修改 | |-----------------------|------------------------------------------------|---------------|-------------------| | `git checkout <branch>` | 切换到指定分支 | ✅ | ❌ | | `git checkout .` | 恢复所有已修改的文件到最近一次提交的状态 | ❌ | ✅ | --- ###
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值