git stash的使用方法

这篇具有很好参考价值的文章主要介绍了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

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

git stash的使用方法,git,git

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 命令显示更加详细的修改

git stash的使用方法,git,git文章来源地址https://www.toymoban.com/news/detail-722809.html

到了这里,关于git stash的使用方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Git的使用方法

    简单来说,Git就像一个日志一样,可以帮你记录你对 文本文件 的修改,但他的功能又强于日志,不仅可以记录,还可以帮你存储那些你对文本文件的修改,当你想要找回之前未修改的文件时,它可以帮你办到。 该文章借鉴了廖雪峰的官方网站 创建一个版本库 在learngit目录下

    2024年02月10日
    浏览(50)
  • Git分支使用方法

    目录 前言 一、查看可用分支 二、创建新分支 三、切换到新分支 四、在新分支上进行工作 五、提交更改 六、切换回主分支 七、删除分支 八、合并分支 九、合并冲突 1、冲突是什么? 2、解决冲突的步骤: 分支是指在同一个代码仓库中的不同版本线。它们可以被用来同时开

    2024年02月10日
    浏览(39)
  • git cz 使用方法

    目录 git cz 的介绍 全局安装 git cz 全局安装changelog,生成changelog的工具 项目下进行配置(配置出现问题可以尝试使用管理员身份运行或者在结尾加上 --force 字段)  在第四点前的操作,每台电脑只用操作一次即可,第四点,需要每个项目都操作安装一遍 git-cz 一款git commit 统一

    2024年02月15日
    浏览(34)
  • Git远程仓库使用方法

    目录 介绍 详细教程 1、创建远程仓库 2、在本地初始化仓库 3、关联远程仓库 4、提交代码 5、拉取到本地仓库 6、提交到Git仓库 5、将本地代码推送到远程仓库 远程仓库在协同开发中起着关键的作用,它提供了一个中央存储库,使多个开发者能够协同工作、共享代码、协同工

    2024年02月11日
    浏览(43)
  • 【git 使用】超级好用的 git reset 和 git revert 功能对比和使用方法

    首先你要知道 git 区分暂存区和工作区,如果你用过 sourcetree 你就会知道 git reset 命令用于将当前分支的 HEAD 指针移动到指定的提交,并且可以选择性地修改工作区和暂存区的状态。 git reset 命令有几种常用的用法,主要包括: git reset --soft commit-id:  被 reset 的提交会放到暂存

    2024年02月20日
    浏览(46)
  • git 的使用方法(上 - 指令)

    在工作中我们的项目一般都是多人合作完成的,这样就需要用到 git 了,跟随本文来一起学习把! Git 是目前世界上最先进的 分布式 版本控制系统。 Workspace :工作区 Index / Stage :暂存区 Repository :仓库区(或本地仓库) Remote :远程仓库 SVN 是 集中式 版本控制系统,版本库

    2023年04月08日
    浏览(36)
  • Git安装与使用方法入门

    目录 Git简介 Git下载与安装 Git配置环境变量 Git使用方法入门 Git是一个帮助开发者追踪代码变化和团队协作的工具。它记录了代码修改的历史,并允许回到过去的版本。开发者可以创建分支来独立开发新功能,而不影响主代码。团队成员可以共享代码,并轻松合并修改。Git提

    2024年02月09日
    浏览(34)
  • Git的作用以及使用方法

    GIT,全称是分布式版本控制系统,git通常在编程中会用到,并且git支持分布式部署。 可以有效、高速的处理从很小到非常大的项目版本管理。分布式相比于集中式的最大区别在于开发者可以提交到本地,每个开发者通过克隆(git clone),在本地机器上拷贝一个完整的Git仓库。

    2023年04月25日
    浏览(36)
  • Git注册、登录和使用方法

    Github官网账号注册网址 首先我们来到Github官网进行账号注册, 如果你还没有账号,点击 sign up 进行注册账号; 如果之前注册过账号的话就点击旁边的 sign in 。 Welcome to GitHub!——欢迎来到GitHub! Let’s begin the adventure——让我们开始冒险吧 Enter your email*——输入您的电子邮件

    2024年04月25日
    浏览(31)
  • Git的安装以及基础使用方法

    Git是一种分布式版本控制系统,被广泛用于管理代码、文档和任何其他类型的数据。它允许开发者在团队中协作,并且在处理大型项目时可以保持代码的完整性。 安装Git:在Linux上,你可以使用包管理器(如apt或yum)来安装Git。在macOS上,你可以使用Homebrew。在Windows上,你可

    2024年02月09日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包