作为开发人员,我们经常会发现自己正在深入编写某个功能,突然有一个紧急问题需要我们立即关注。为了解决这个问题,我们需要切换 git 中的分支。但是,如果我们尚未提交当前的更改,那么这样做可能会有风险。我们可能会失去工作或面临合并冲突。
在这篇文章中,我将引导您了解两种在 git 中切换分支而不丢失更改的有效策略。
想象一下您正在当前分支中开发一项新功能。您已经进行了多项更改,但尚未提交。突然,您收到修复另一个分支中的错误的请求。困境:如何切换到另一个分支来解决问题而不丢失所做的更改?
git 提供了一些强大的工具来顺利处理这种情况:git stash 和创建临时分支。
什么是 git stash?
git stash 是一个命令,允许您临时保存(或“隐藏”)您的更改而不提交它们。当您需要切换分支但又想稍后返回当前工作而不丢失任何内容时,这非常有用。
以下是隐藏更改的方法:
隐藏您的更改:
运行以下命令来存储您的更改:
git stash
此命令保存您未提交的更改并重置您的工作目录以匹配上次提交。
切换到另一个分支:
现在你的工作目录是干净的,你可以安全地切换到另一个分支:
git checkout <branch-name>
根据需要修复其他分支的紧急问题。
解决问题后,切换回原来的分支:
git checkout <original-branch>
然后,使用以下命令恢复您隐藏的更改:
git stash pop
此命令将存储的更改应用回您的工作目录,并从存储列表中删除存储。
假设您正在开发功能分支中的一项功能,并且收到修复 master 中错误的请求:
使用 git stash 保存更改:
git 存储
切换到主分支:
git checkout大师
修复 master 中的错误并提交更改。
切换回功能分支:
git checkout 功能分支
恢复您隐藏的更改:
git stash pop
现在,您回到了上次离开的地方,所有更改都完好无损。
另一种方法是将更改提交到临时分支。如果您更喜欢在切换分支之前提交工作,这非常有用。
首先,创建并切换到一个新的临时分支:
git checkout -b temp-branch
在您解决紧急问题时,该分支机构将保留您当前的工作。
在临时分支中提交你的工作:
git add . git commit -m "wip: save work before switching branches"
现在,切换到您需要进行紧急更改的分支:
git checkout <branch-name>
解决问题后:
返回原来的分支:
git checkout <original-branch>
如果您想将临时分支中的工作带回原始分支,您可以合并它:
git merge temp-branch
完成后,您可以删除临时分支:
git branch -d temp-branch<br>
让我们看一个简单的例子:
创建并切换到临时分支:
git checkout -b 临时修复
提交当前更改:
git add . git commit -m "wip: 切换分支前临时保存"
切换到所需的分支来解决问题:
复制代码
git checkout大师
修复问题后,切换回原来的分支:
复制代码
git checkout 功能分支
如果需要,可以选择合并临时分支。
即使有未提交的更改,在 git 中切换分支也可以顺利且无压力。通过利用 git stash 或创建临时分支,您可以无缝管理您的工作流程并保持进度不变。这些技术可帮助您快速解决紧急问题,而不会丢失任何正在进行的工作。
在您的下一个项目中尝试这些方法,看看它们如何增强您的开发过程!
我希望这篇关于使用 git stash 的指南对您有所帮助。如果您有任何疑问或需要更多详细信息,请随时在下面发表评论。
与我联系:
github:- 探索我的开源项目和存储库。
linkedin: - 与我进行专业联系并随时了解我的职业生涯。
请随时在这些平台上联系或关注我,以获取更多见解、更新和机会。感谢您的阅读!