git stash 缓存代码相关操作

1.基本用法

1.1保存当前代码

复制代码
git stash

作用:将当前工作目录中的所有未提交的更改(包括暂存区和工作区的更改)保存到一个"stash"中,并将工作目录恢复到最近一次提交的状态。

1.2 保存更改并添加描述

arduino 复制代码
git stash save "描述信息"

作用:保存当前更改,并为 stash 添加描述信息,方便后续查找。

示例

arduino 复制代码
git stash save "临时保存未完成的特性"

2. 查看所有保存的 Stash

复制代码
git stash list

作用:列出所有保存的 stash,显示每个 stash 的名称、描述和保存时的分支信息。

输出示例:

less 复制代码
stash@{0}: WIP on main: commit-hash 描述信息
stash@{1}: WIP on feature: commit-hash 另一个描述

3. 恢复 Stash

3.1 恢复最新的 Stash

perl 复制代码
git stash pop

**作用:**将最新的 stash 应用到当前工作目录,并从 stash 列表中删除该 stash。

**注意:**如果有冲突,Git 会提示冲突信息,需要手动解决。

3.2 恢复指定的 Stash

kotlin 复制代码
git stash apply stash@{索引}
// 可能会发生报错,需要加上'',后续需要指定stash的都是如此
git stash apply 'stash@{索引}'

**作用:**将指定的 stash 应用到当前工作目录,但不会从 stash 列表中删除。

示例:

kotlin 复制代码
git stash apply stash@{1}
// or
git stash apply 'stash@{1}'

3.3 恢复并删除指定的 Stash

kotlin 复制代码
git stash pop stash@{索引}

**作用:**将指定的 stash 应用到当前工作目录,并从 stash 列表中删除。

示例:

perl 复制代码
git stash pop stash@{1}
// or
git stash pop 'stash@{1}'

4. 删除 Stash

4.1 删除最新的 Stash

sql 复制代码
git stash drop

**作用:**删除最新的stash

4.2 删除指定的 Stash

kotlin 复制代码
git stash drop stash@{索引}

**作用:**删除指定的stash

用例:

kotlin 复制代码
git stash drop stash@{1}
// 
git stash drop 'stash@{1}'

4.3 清空所有 Stash

arduino 复制代码
git stash clear

**作用:**删除所有保存的stash

5. 查看 Stash 的内容

5.1 查看最新的 Stash

sql 复制代码
git stash show

**作用:**显示最新的 stash 中的更改。

5.2 查看指定的 Stash

kotlin 复制代码
git stash show stash@{索引}

作用:显示指定 stash 的更改。

5.3 查看 Stash 的详细内容

css 复制代码
git stash show stash@{索引} -p

**作用:**以补丁的形式显示指定 stash 的详细更改。

6. 常见场景

6.1 切换分支前保存更改

当你正在工作时,需要切换到另一个分支,但不想提交当前的更改:

复制代码
git stash
git checkout other-branch

6.2 恢复更改并继续工作

当你完成其他任务后,回到原来的分支并恢复更改:

perl 复制代码
git checkout original-branch
git stash pop

6.3 清理工作目录

如果你发现某个 stash 已经不再需要,可以直接删除:

kotlin 复制代码
git stash drop stash@{索引}
相关推荐
Jooolin9 小时前
【编程史】Git是如何诞生的?这可并非计划之中...
linux·git·ai编程
Lw老王要学习13 小时前
VScode 使用 git 提交数据到指定库的完整指南
windows·git·vscode
去旅行、在路上13 小时前
Git & Svn
git·svn
abcnull14 小时前
github中main与master,master无法合并到main
git·github
养意20 小时前
git提交代码和解决冲突修复bug
git·bug
码农黛兮_461 天前
Git 常用命令大全
git
一弓虽1 天前
git 学习
git·学习
疯狂的沙粒2 天前
如何通过git命令查看项目连接的仓库地址?
大数据·git·elasticsearch
qq_254617772 天前
Gerrit+repo管理git仓库,如果本地有新分支不能执行repo sync来同步远程所有修改,会报错
git
π大星星️2 天前
Git分布式版本控制工具
分布式·git