git stash的使用方法

git stash的使用方法

应用场景

当我们在开发一个新功能的时候,或者开发到一半,然后就收到了线上master 出现了bug,当分支开发已经进行了或者进行到一半了,这时怎么办呢?

这时解决方案有两种:一种是先先将当前开发种的代码提交到分支上去,虽然可以解决问题但是不妥。第二个分案切换一个新的分支明显也不妥。

git stash 初识

git stash 命令恰好可以解决这个问题,可以将当前 【未提交 add . || git add 命令执行前的修改】==【工作区的修改和暂存区的修改先暂时粗存起来】 ,这样后工作区就干净了,可以直接切换到master分支下拉拉代码修改了,修改完bug后,重新切换到刚刚 还在开发中的分支,执行 git stash pop 命令将之前存储的修改取出来继续开发。

基本使用

git stash 命令将当前工作目录的修改或者暂存区修改的保存的命令。

它会将当前未提交的更改保存到一个临时的存储区域,方便切换分支或者更改其他功能时,能回到当前工作状态。

PS D:\work\DSP\xxxx-web> git stash
Saved working directory and index state WIP on bin0705: 935b6e2 xxxxx

git stash 查看工作区就很干净

PS D:\work\DSP\xxx-web> git status
On branch bin0705
Your branch is up to date with 'origin/bin0705'.

nothing to commit, working tree clean

通过 git stash list 命令用于或者当前存储区(stash )中的所有暂存记录。会显示 每个暂存记录的唯一标识(stash@{n}) 以及描述信息

PS D:\work\DSP\xxx-web> git stash list
stash@{0}: WIP on bin0705: 935b6e2 xxxxxxxxxxxx


//git stash list 每条描述信息的解释
stash@{0}: WIP on bin0705: 935b6e2 xxxxxxxxxxxx
stash@{0}: WIP on bin0705>[分支]: 935b6e2>[最近一次的commitID] xxxxxxxxxxxx>[最近一次的提交信息==最近一次commit 的信息]

git stash save "描述信息"

用于将当前工作目录开发的代码和暂存区的修改保存到一个新的暂存记录中。于git stash 不同的是它允许提供一个描述信息来标识改暂存记录。

git stash save 这个命令在git 2.13版本后被弃用了 ,推荐使用 git stash push -m "描述信息"

git version 查看 当前安装的git 版本
git version 2.35.1.windows.2

git stash save "描述信息"

git stash push

1、不添加描述信息

git stash push 正常使用就行

2、添加描述信息:

git stash push -m "描述信息"

git stash save 的新替换语法,使用方式跟git stash save 一样

PS D:\work\DSP\xxx-web> git stash push -m '测试新git stash push 这个新语法'
Saved working directory and index state On bin0705: 测试新git stash push 这个新语法
PS D:\work\DSP\xxx-web> git stash list
stash@{0}: On bin0705: 测试新git stash push 这个新语法

查看git stash push 添加的存储

PS D:\work\DSP\xxx-web> git stash list
stash@{0}: On bin0705: 测试新git stash push 这个新语法

3、保存指定文件或路径的修改

git stash push <file-path>

取出存储

1、git stash apply stash@{index} 取出指定 index 的存储的修改到工作区

git stash apply stash@{index}

这个命令如果不行的话就使用这个语法
git stash apply 1

git stash apply stash@{index} 无效的错误

fatal: unknown subcommand: stash@

usage: git stash list [<options>]
   or: git stash show [<options>] [<stash>]
   or: git stash drop [-q|--quiet] [<stash>]
   or: git stash ( pop | apply ) [--index] [-q|--quiet] [<stash>]
   or: git stash branch <branchname> [<stash>]
   or: git stash clear
   or: git stash [push [-p|--patch] [-S|--staged] [-k|--[no-]keep-index] [-q|--quiet]
                 [-u|--include-untracked] [-a|--all] [-m|--message <message>]
                 [--pathspec-from-file=<file> [--pathspec-file-nul]]
                 [--] [<pathspec>...]]
   or: git stash save [-p|--patch] [-S|--staged] [-k|--[no-]keep-index] [-q|--quiet]
                 [-u|--include-untracked] [-a|--all] [<message>]

2、git stash drop [index] 将指定index的存储从存储记录列表中删除

git stash drop stash

效果:
PS D:\work\DSP\xxxxx-web> git stash drop 0
Dropped refs/stash@{0} (717810cda5783b0ab14bc5a91ef4904eee82ed86)
找不到了:
PS D:\work\DSP\xxxxx-web> git stash list
PS D:\work\DSP\xxxxx-web>

3、git stash apply 取出最近一次修改但是不删除

git stash apply

取出后,不会影响存储区列表

4、git stash pop 取出最近一条并删除列表中记录

git stash pop 取出最近一次存储的修改到工作区,并且同时将该取出的存储记录从列表删除

取出存储发现取错了怎么办

取出存储发现取出了怎么办,又忘记使用描述怎么办,那么多存储记录,又没描述,都不知道该存储记录是干什么的,又不能通过重新取出存储的命令【会出现取出存储合并】,又没有退出的命令,又不能删除。

解决方法:

将当前取出的存储重新存进去,虽然会导致重复的,可以将重复的删除

git stash push -m '隐藏66' 

建议使用取出存储的时候命令顺序

//不同git版本命令有所差异
git stash pop stash@{2} 或 git stash pop 1    // 取出指定标识的存储,并将其标识的存储从列表中删除,如果只有一个使用 git stash pop 就可以了。

//这样即使取错了可以重新存储,又不会导致存储列表出现重复
git stash push -m '隐藏66' 

删除所有暂存区记录

git stash clear 命令,可以清除暂存区的所有暂存记录,并且无法恢复。

在智次git stash clear 命令之前,请确保你已经备份了需要保留的暂存记录,因为一旦清除,暂存记录将无法恢复

PS D:\work\DSP\xxxx-web> git stash clear
PS D:\work\DSP\xxxx-web> git stash list
PS D:\work\DSP\xxxx-web>

git stash 查看内容

1、查看最近的暂存记录的更改内容

git stash show

效果:
PS D:\work\DSP\xxxxx-web> git stash show
 src/views/febs/xxxxx/xxxxx/index.vue | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
PS D:\work\DSP\xxxxx-web>

2、查看特定暂存记录(通过标识符)的更改内容

git stash show stash@{2}

// 跟上面效果一样,只不过是指定存储区的下标而已
PS D:\work\DSP\xxxxx-web> git stash show 0
 src/views/xxxxx/xxxxx/xxxxx/index2.vue | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
PS D:\work\DSP\xxxxx-web>

3、显示更详细的暂存记录信息(包括文件差异)

git stash show -p 命令显示更加详细的修改

相关推荐
算你狠 - ZGX2 小时前
Git使用
git
Lojarro8 小时前
【后端】版本控制
git·subversion
MengYiKeNan14 小时前
Git配置与使用
git
shall_zhao14 小时前
修改仓库中子模块并推送到远程仓库的指定分支
git
鱼钓猫的小鱼干16 小时前
Git 安装
git
子洋16 小时前
迁移 Gitlab 到 Forgejo
前端·git·后端
爱串门的小马驹18 小时前
git,ssh免密公钥配置,gitee为例,GitHub,gitlab同理
运维·git·ssh
小小小妮子~19 小时前
掌握Git分布式版本控制工具:从基础到实践
分布式·git
前端与小赵1 天前
什么是Git,有什么特点
git