最近在使用Git管理项目工程的时候,遇到了很多问题,也学习到了很多关于Git常见使用的技巧,下面就其中关于Git Stash的用法和大家分享下。
首先,简单介绍下Git Stash命令的用法,详细的用法在man文档中有相关介绍,下面我来说明常见的使用。
git stash: 备份当前的工作区的内容,从最近的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。同时,将当前的工作区内容保存到Git栈中。
git stash pop: 从Git栈中读取最近一次保存的内容,恢复工作区的相关内容。由于可能存在多个Stash的内容,所以用栈来管理,pop会从最近的一个stash中读取内容并恢复。
git stash list: 显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。
关于Git Stash的详细解释,适用场合,这里做一个说明:
在这里顺便提下git format-patch -n , n是具体某个数字, 例如 'git format-patch -1' 这时便会根据log生成一个对应的补丁,如果 'git format-patch -2' 那么便会生成2个补丁,当然前提是你的log上有至少有两个记录。
看过上面的信息,就可以知道使用场合了:当前工作区内容已被修改,但是并未完成。这时Boss来了,说前面的分支上面有一个Bug,需要立即修复。可是我又不想提交目前的修改,因为修改没有完成。但是,不提交的话,又没有办法checkout到前面的分支。此时用Git Stash就相当于备份工作区了。然后在Checkout过去修改,就能够达到保存当前工作区,并及时恢复的作用。
下面,将我使用过程中遇到的一个问题和大家分享:
首先,在Git Stash之后,提交图如下所示:
从图中可以看到,develop和newdevelop是在同一个分支上,因为分支newdevelop是在develop分支的基础上开发的。想加入一个新的特性,所以就开了newdevelop分支,然后就在上面加东西,加特性,该代码。这个时候工作的内容已经变化了,但是develop和newdevelop都是指向同一个提交的,因为newdevelop上面还木有提交。
这个时候,Boss来了,说develop上面有个Bug,赶快改一下,手头的工作先放放,稳定版本不能有缺陷。没办法,当前正在newdevelop上搞的high呢,就Git Stash一下。所以会看到上面有两个节点,红色以及上面一个。就是stash之后的结果,注意是在newdevelop上面进行的stash。
正如前面所说,stash会暂存当前的工作区内容,然后将工作区内容保持和上次提交相同,此时内容都是上面8a32那个提交的内容。从终端中查看相应的信息内容,如下:
印证了签名的说法,newdevelop是有修改,modified,然后stash之后,工作区是最近一次提交,此时newdevelop和develop都是相同的,所以再git status查看发现,都一样,nothing to commit.
然后Stash完成之后,就要Fix Bug了。为此,回到develop分支上进行修复,然后提交,完成后的提交图如下所示:
从途中可以看到,newdevelop还是在下面,因为指向的是老的那个8a32的commit。新的develop由于修复了Bug,所以产生一个新提交。
然后在develop上面修复了Bug之后,在回到newdevelop上面进行一个新的特性的继续编码,此时checkout回去的时候,没有神马内容可以提交,因为都存在Stash中了,没有任何修改。如上图。
那么,恢复工作区内容吧。于是git stash pop(注意这里由于只Stash了一次所以使用pop,具体你存放了多少,要恢复哪一个要自己清楚,否则会出错!)
恢复之后,从上图中可以看到,此时再git status就会发现文件有修改,说明恢复过来了。然后就继续编码,提交一个稳定的新特性版本,如下图,产生的新提交为0906.
然后再查看提交图,会发现,stash pop之后,对应的存放的stash被清空掉了,提交图中,newdevelop上面对应一个新的提交。并且在develop上面。分支的develop那个红色,即为前面修复Bug的那个提交。
总结起来:
操作很简单,但是头脑要清楚。要在哪个分支上修复Bug,要暂存哪个地方的内容,之后修复完了在那个地方提交,然后要到哪个分支上面恢复工作区,都是需要注意的,否则,很容易造成提交图混乱。只有弄清楚了工作流程,才不容易出错,才能保证很高的工作效率。
最后一句:Git是神器,就要看你如何驾驭它了。
原文链接:http://www.cppblog.com/deercoder/archive/2011/11/13/160007.html
相关推荐
用法 $ npm install -g @mattbun/oops $ oops COMMAND running command... $ oops (-v | --version | version) @mattbun/oops/0.0.3 linux-x64 node-v12.19.0 $ oops --help [COMMAND] USAGE $ oops COMMAND ... ...
9.2 使用 git stash/ 108 9.3 探秘 git stash/ 109 第10章 Git 基本操作/ 114 10.1 先来合个影/ 114 10.2 删除文件/ 114 10.2.1 本地删除不是真的删除/ 115 10.2.2 执行 git rm 命令删除文件/ 116 10.2.3 命令git ...
主要介绍了IDEA中使用Git拉取代码时报 Git pull failed原因及解决方法,本文给大家介绍的非常详细对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
git下载将远程git存储库下载到目录或... 将来可能会增加使用其他下载方法添加github支持的功能。安装npm install git-download --save用法var options = { // Remote source location (no github sources) source: 's
gitstashlist显示当前工作区中包含的stash。gitstashpop恢复工作区的修改,同时删除标识符。查看当前git的用户名和邮箱;当我们在编写代码过程中,可能由于某种原因,我们想要回退到最初的修改之前,那么应该怎么做...
git-command 以下 git 命令之一:init、clone、status、checkout、branch、merge、commit、push、add、stash 美联储.json 列出所有目录及其 git 存储库: { "dirs" : [ { "name" : "repo1",
较紧, 可以看看TortoiseGit的帮助文档, 对Git的用法, 文件存储等都会有比较好 的了解. 对比常用的 CVS, Git 至少有以下几个优点: 不需要连接服务器就能实现版本管理; 一个库不管有多少层目录, 只有一个管理目录 ...
互动媒体介绍NYU Abu Dhabi类IM-UH 1010的代码示例。用法初始化(您只需执行以下步骤一次): ... 要获得新的示例: git pull 如果不确定是否已在回购中直接处理过示例,则可以在拉动之前隐藏所有内容: git stash git
在Stash git存储库产品中,git存储库按ID(而不是其URL)存储。 因此,每个文件的格式repoid.Extension 。 扩展名是HEAD , repo或log 。 HEAD文件是HEAD引用的文件。 repo文件是URL。 log文件是git log --raw --...
藏书本 TODO:在此处输入食谱说明。 例如,这本食谱使您最喜欢的早餐三明治。 要求 TODO:列出您的食谱要求。 确保包含本说明书对平台、库、其他说明书、软件包、操作系统等的任何要求。...在 Git
以后您可以像git stash一样通过apply或pop方法取消格式化,然后重新打开选项卡会话。安装包装控制使用 ,Sublime Text的程序包管理器。 按“ cmd + shift + p”,然后键入“ Package Control:添加存储库”,按...
git clone https://github.com/ElectiSoft/auto-stash cd auto-stash yarn # or npm install (install dependencies) 用法 yarn start [optional arguments] -s/--search SEARCH required arguments: -s SEARCH, --...
介绍了2种方法,个人推荐方法2,比较好理解。git merge冲突时如何解决问题描述Commit your changes or stash them befo
git-stash的整个概念是将更改保存在肮脏的工作目录中。 无法与其他贡献者共享您保存的文件。 :light_bulb: 特征 :card_index_dividers: 一次上传多个文件 :stopwatch: 报告每一步 :locked: 将GitHub令牌安全地...
npm install -g git+ssh://git@stash.redventures.net/srch/koa-ng-boilerplate.git 现在,假设您的全局 node_modules 在您的 $PATH 中,您应该能够使用命令“koa-ng-boilerplate”。 只有一个参数:“--name”。 ...
藏匿轮盘使用 ReactJS 创建的增量储蓄游戏选择一个起始量,然后是一个增量器和一个频率。 看看如果您坚持该计划,您将节省多少!...)用法 git clonenpm installnpm startopen http://localhost:3000
安装使用docstash的最简单方法是通过 PyPI: $ pip install docstash 或者,从 GitHub 检出存储库并在本地安装: $ git clone https://github.com/pudo/docstash.git$ cd docstash$ python setup.py develop例子...
:cyclone: 门户网站安装brew install erictsiliacos/tap/portal 用法您可以使用--help选项来获取有关命令及其选项的更多详细信息入门使用或设置相同的配对推根据您的配对将本地更改推送到远程分支portal push 选项 -...
从StaSh Shell运行git clone https://github.com/p4lsec/iCoT.git 从左侧菜单中找到并打开iCoT文件夹 方法2: 单击此处下载此脚本: : 通过在“文件”应用中单击文件来解压缩文件 打开Pythonista,单击外部文件>...
信用到期:该项目非常接近于 Nicola Paolucci 的 Stash 配置示例 。 查看了解更多详情 依赖关系 用法 $ git clone https://github.com/lwndev/confluence-vagrant-install.git && cd confluence-vagrant-install $...