暂存代码 - 每天三分钟玩转Git(四)

简介: 暂存代码 - 每天三分钟玩转Git(四)

“ 我真的不想在吃火锅的时候,突然拿出电脑来改bug ——编程三分钟”


3bf2b331cafb44c6c0e32a0b36531fea.jpg第 4 篇

暂存代码


当我们在好好的写一个新功能时,线上临时十万火急的bug,正在吃火锅的你在这个时候必须放下手中夹起的肥牛,打开电脑修复bug


git历史文章:


Git概念、安装与配置


Git 单人操作与基本使用


合并冲突


暂存代码保护现场


这种情况一般是出现在你正在完成一个功能,但是忽然线上发现了一个Bug,必须马上开一个新的分支来修复bug,但是现在的功能没写完不打算提交(commit),现在怎么办??


不用怕!暂存代码来帮助你。请看下图内容

cb1e393e57f8b312a677dd1e20338352.jpg


status查看到有2个文件修改没有提交


680636a45da7346603edf06c1ffc1aca.jpg



git stash命令可以把现在的工作区全部的修改,包括新文件,修改、删除等所有的操作,全部保存起来,恢复现场,把修改放到暂存区并用上一次的commit信息来命名这次储存(用一个别名来条记录,这里记作 stash@{0},方便使用)


git stash list列出暂存区所有记录,如果有多次暂存就会有多条记录,可以看到此时有一条记录

7396fffa7ead1647f9d2c42db5565d27.jpg

我们可以看到,现在的工作区多么的清爽

为了凸显,暂存代码的主题,我们省略掉一些操作:

  1. 创建一个bug分支
  2. 修复现有bug
  3. 修复完成后提交到主线
  4. 切回来当前分支继续开发

下面来恢复现场


7595e23260a49d967e8b5c7916e57854.jpg

git stash apply重新把暂存区内容放到本地


有的朋友问我为什么要用命令行,用可视化页面不可以吗?


还真的是可以的,但是命令行最好的作用就是像一本指导书一样,就像上面的图片,输入一个命令下面会自动给出各种提示,非常方便


而且懂命令行还可以保证操作不会因为可视化工具的翻译问题而误操作


一些高级操作像不小心把代码删掉了,只会可视化页面基本只能哭了


清理缓存


上一节的git stash apply成功的把暂存区的一次暂存恢复到了本地,但是暂存区还有会保存这次暂存,如果想删除这次暂存要用git stash drop来删除;也可以用git stash pop,恢复最后一次暂存的同时把stash内容也删了。

43cc90b7cb233668780afc5bc3b7e099.jpg

好了,暂存区清干净了。


  注意:要放到暂存区的文件一定要先通过git add加到index


小结


本次的三分钟就到这里啦,这一节我们学会了以下命令


git stash 暂存我们的工作区现场


git stash list列出暂存区所有记录,如果有多次暂存就会有多条记录


git stash apply stash@{0}把暂存区的记录恢复到本地


git stash drop stash@{0}精准删除暂存记录或者git stash pop恢复的同步删除最后一条暂存记录


PS: 谢谢朋友们的建议,要对得起编程三分钟这个名字,真正的只用三分钟就可以读完一个知识点(理解可能要花一点时间),充分利用起大家的碎片化时间,我会努力的,谢谢你们我的朋友们!

相关文章
|
2天前
|
Devops Shell 网络安全
git使用之如何将一套代码同时推送至github|gitee|gitcode|gitlab等多个仓库-含添加ssh-优雅草央千澈完美解决-提供整体提交代码
git使用之如何将一套代码同时推送至github|gitee|gitcode|gitlab等多个仓库-含添加ssh-优雅草央千澈完美解决-提供整体提交代码
git使用之如何将一套代码同时推送至github|gitee|gitcode|gitlab等多个仓库-含添加ssh-优雅草央千澈完美解决-提供整体提交代码
|
5月前
|
IDE 网络安全 开发工具
【Azure App Service】Local Git App Service的仓库代码遇见卡住不Clone代码的问题
【Azure App Service】Local Git App Service的仓库代码遇见卡住不Clone代码的问题
【Azure App Service】Local Git App Service的仓库代码遇见卡住不Clone代码的问题
|
5月前
|
开发工具 git Python
通过Python脚本git pull 自动重试拉取代码
通过Python脚本git pull 自动重试拉取代码
213 5
|
3月前
|
存储 开发工具 数据安全/隐私保护
全面掌握 Git 基本操作与暂存技巧
本文详细介绍了 Git 的基本操作流程,包括查看文件状态、代码拉取、文件添加与提交、以及推送到服务器的步骤。同时,探讨了 Git 暂存的相关命令,如暂存、恢复和删除等,帮助开发者有效管理代码更改与版本控制。此外,还提供了如何找回暂存代码的技巧,以确保数据安全。
45 2
|
3月前
|
开发工具 git
git如何修改提交代码时的名字和邮箱?
git如何修改提交代码时的名字和邮箱?
287 4
|
3月前
|
Java Linux 开发工具
IDEA中git提交前如何关闭code analysis以及开启格式化代码
【10月更文挑战第12天】本文介绍了在 IntelliJ IDEA 中关闭代码分析和开启代码格式化的步骤。关闭代码分析可通过取消默认启用检查或针对特定规则进行调整实现,同时可通过设置 VCS 静默模式在提交时跳过检查。开启代码格式化则需在 `Settings` 中配置 `Code Style` 规则,并通过创建 Git 钩子实现提交前自动格式化。
860 3
|
4月前
|
Shell 网络安全 开发工具
git与gitee结合使用,提交代码,文件到远程仓库
本文介绍了如何将Git与Gitee结合使用来提交代码文件到远程仓库。内容涵盖了Git的安装和环境变量配置、SSH公钥的生成和配置、在Gitee上创建仓库、设置Git的全局用户信息、初始化本地仓库、添加远程仓库地址、提交文件和推送到远程仓库的步骤。此外,还提供了如何克隆远程仓库到本地的命令。
git与gitee结合使用,提交代码,文件到远程仓库
|
3月前
|
JavaScript 前端开发 开发工具
一身反骨的我,用--no-verify绕开了git代码提交限制!
【10月更文挑战第7天】一身反骨的我,用--no-verify绕开了git代码提交限制!
182 0
|
5月前
|
Shell 开发工具 git
使用 Shell 代码简化 Git 步骤
【8月更文挑战第23天】本文介绍通过Shell脚本简化Git操作的方法:1) 使用`gitc "提交信息"`可一键完成代码提交与推送至远程仓库;2) 执行`gitpull`即可从远程仓库拉取最新代码并合并到当前分支;3) 输入`gitnewbranch 分支名称`快速创建并切换到新分支。将这些自定义函数加入`.bashrc`或`.zshrc`等配置文件后,即可随时调用简化版Git命令。
|
5月前
|
前端开发 JavaScript PHP
【Azure 应用服务】App Service 在使用GIt本地部署,上传代码的路径为/home/site/repository,而不是站点的根目录/home/site/wwwroot。 这个是因为什么?
【Azure 应用服务】App Service 在使用GIt本地部署,上传代码的路径为/home/site/repository,而不是站点的根目录/home/site/wwwroot。 这个是因为什么?