最近在使用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
相关推荐
- 通过 `git stash list` 查看 stash 并使用 `git stash apply stash@{n}` 来应用特定的 stash。 - 如果不再需要某个 stash,使用 `git stash drop stash@{n}` 删除它。 综上所述,Git Stash 是 Git 中一个强大的...
- **`apply` 命令**:`git stash apply stash@{index}` 类似于 `pop`,但不会从列表中删除 stash,这样你可以在稍后再次应用它,或者使用 `drop` 命令手动删除。 7. **删除暂存** - **删除指定的暂存**:`git ...
在实际开发中,使用Git解决冲突的方法非常简单,只需要使用git stash命令将本地修改暂时存储起来,然后pull最新的代码,最后还原暂存的内容。同时需要注意,在解决冲突时,需要自行确定需要的内容,并编辑解决冲突,...
### Git使用技巧详解 #### 忽略特定文件与目录 在使用Git进行版本控制时,经常需要排除一些不必要的文件或目录,比如编译生成的文件、日志文件等,以免这些文件占用版本库的空间或者泄露敏感信息。这时,`....
通过以上内容的学习,我们不仅了解了如何处理Git冲突,还掌握了几个常用的Git命令及其使用方法。这对于提高团队协作效率和代码管理能力具有重要意义。在实际开发过程中,合理运用这些知识可以帮助我们更高效地管理...
在Linux开发中,理解并掌握Git的各种命令及其用法是至关重要的,自定义命令和别名则是提升效率的有效手段。通过自定义`git checkout`命令来自动管理`git stash`,可以帮助开发者更加专注地进行代码开发,减少因分支...
### Git命令手册知识点详解 #### 一、配置个人信息 ...以上是基于提供的文件内容所整理出的主要Git命令及其用法。通过这些命令,你可以有效地管理项目的历史版本、协同开发以及解决日常工作中遇到的问题。
下面是Git常见使用命令参考,涵盖了Git的基本使用方法和进阶使用技巧。 Git初始设置 在使用Git之前,需要进行初始设置,包括设置用户名和电子邮件地址。使用以下命令可以设置用户名和电子邮件地址: git config -...
Git 是一个分布式版本控制系统,广泛应用于软件开发和其他需要版本管理的场景。本文将介绍一些Git的高级用法,帮助你更好地理解和掌握Git的功能。...记得适时使用`git help`或查阅官方文档以获取更多关于Git的知识。
### Git基本操作知识点详解 #### 一、Git简介 Git是一种开源的分布式版本控制系统,能够高效地处理从小...通过以上内容的学习和实践,您将能够掌握Git的基本使用方法,并能够有效地利用Git进行团队协作和版本控制。
`git stash apply` 或 `git stash pop` 可以将暂存的变更应用到当前分支,`git stash branch` 则可以创建一个新的分支并应用暂存的变更。 混淆是一种安全措施,通常在Android开发中使用,目的是使得反编译后的代码...
根据提供的标题、描述、标签及部分内容,我们可以梳理出关于Git的基本使用方法以及分支管理和冲突解决的相关知识点。 ### Git基础知识 #### 创建与初始化仓库 - **`mkdir`**: 用于创建一个新的目录。例如,如果你...
用法 $ 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 ... ...
### Git入门笔记知识点总结 ...以上内容覆盖了Git的基本操作、版本管理和远程仓库交互等内容,适合初学者快速掌握Git的基本使用方法。通过这些命令的学习与实践,可以有效地利用Git进行版本控制和团队协作。
Git 和 Gerrit 是在软件开发领域中常用的工具,它们分别用于版本控制和代码审查。Git 是一个分布式版本控制系统,能够追踪文件和目录的修改...理解并熟练掌握这些工具的使用方法和规范,对于软件开发人员来说至关重要。
Git是分布式版本控制系统,用于跟踪对文件和项目更改的历史...在实际开发中,还会遇到更多高级用法,如标签(tag)、重置(reset)、合并冲突(merge conflict)等,这些都是Git功能的延伸,有助于更高效地管理项目。
以上只是Git众多命令和概念的一小部分,完整的文档将包含更多实用技巧和复杂情况的处理方法,如解决合并冲突、协作工作流等。通过深入学习这份文档,你可以掌握Git的全面功能,更好地进行代码管理和团队协作。
本章节将详细介绍一些Git中最常用的操作命令及其应用场景,帮助读者更深入地掌握Git的基本使用方法。 1. **查看帮助信息**:`git help -g`,显示Git的常见指南,例如`attributes`、`cli`等。 2. **回到远程仓库的...
Git 是一个分布式版本控制系统,广泛应用于软件开发和项目协作中。...在实际工作中,还会遇到更多高级用法,如标签(tag)、重置(reset)、rebase 等,不断学习和实践,将使你在 Git 使用上更加得心应手。
通过上述知识点的介绍,初学者可以更好地理解Git的基本原理及其使用方法。Git不仅是一种版本控制系统,也是一种强大的工具,可以帮助开发者高效地管理代码变更和协作。希望这些知识点能够帮助你更好地掌握Git,并在...