Git-操作分支

本文详细介绍了Git的分支管理、合并、检出和暂存功能,包括gitbranch用于查看和管理分支,gitmerge进行分支合并,gitcheckout用于切换和创建分支,以及gitstash用于保存工作进度。内容涵盖各种命令的使用场景和操作示例,旨在帮助开发者更好地理解和运用Git工具。
摘要由CSDN通过智能技术生成

一、git branch

git branch:查看、创建、删除分支

查看本地版本库和远程版本库上的分支列表:

$ git branch -a

分支未提交到本地版本库前强制删除分支:

$ git branch -r

查看远程版本库上的分支列表,加上 -d 参数可以删除远程版本库上的分支:

$ git branch -D

查看带有最后提交id、最近提交原因等信息的本地版本库分支列表:

$ git branch -vv

查看带有最后提交id、最近提交原因等信息的本地版本库分支列表

二、git merge

git merge:将其它分支合并到当前分支

将待合并分支上的 commit 合并成一个新的 commit 放入当前分支,适用于待合并分支的提交记录不需要保留的情况:

$ git merge --squash

默认情况下,Git 执行" 快进式合并 "(fast-farward merge),会直接将 Master 分支指向 Develop 分支,使用 --no-ff 参数后,会执行正常合并,在 Master 分支上生成一个新节点,保证版本演进更清晰:

$ git merge --no-ff

在这里插入图片描述
在没有冲突的情况下合并,不想手动编辑提交原因,而是用 Git 自动生成的类似 Merge branch 'test'的文字直接提交:

$ git merge --no-edit

三、git checkout

git checkout:切换分支

创建 daily/0.0.1 分支,同时切换到这个新创建的分支:

$ git checkout -b daily/0.0.1

从本地版本库的 HEAD(也可以是提交ID、分支名、Tag名) 历史中检出 demo.html 覆盖当前工作区的文件,如果省略 HEAD 则是从暂存区检出:

$ git checkout HEAD demo.html

这个命令会创建一个全新的,完全没有历史记录的新分支,但当前源分支上所有的最新文件都还在,真是强迫症患者的福音,但这个新分支必须做一次 git commit 操作后才会真正成为一个新分支:

$ git checkout --orphan new_branch

这个命令主要用来比较两个分支间的差异内容,并提供交互式的界面来选择进一步的操作,这个命令不仅可以比较两个分支间的差异,还可以比较单个文件的差异:

$ git checkout -p other_branch

四、git stash

git stash:在 Git 的栈中保存当前修改或删除的工作进度,当你在一个分支里做某项功能开发时,接到通知把昨天已经测试完没问题的代码发布到线上,但这时你已经在这个分支里加入了其它未提交的代码,这个时候就可以把这些未提交的代码存到栈里。

将未提交的文件保存到Git栈中:

$ git stash

查看栈中保存的列表:

$ git stash list

显示栈中其中一条记录:

$ git stash show stash@{0}

移除栈中其中一条记录:

$ git stash drop stash@{0}

从Git栈中检出最新保存的一条记录,并将它从栈中移除:

$ git stash pop

从Git栈中检出其中一条记录,但不从栈中移除:

$ git stash apply stash@{0}

把当前栈中最近一次记录检出并创建一个新分支:

$ git stash branch new_banch

清空栈里的所有记录:

$ git stash clear

为当前修改或删除的文件创建一个自定义的栈并返回一个ID,此时并未真正存储到栈里:

$ git stash create

将 create 方法里返回的ID放到 store 后面,此时在栈里真正创建了一个记录,但当前修改或删除的文件并未从工作区移除:

$ git stash store xxxxxx

如:

$ git stash create
09eb9a97ad632d0825be1ece361936d1d0bdb5c7
$ git stash store 09eb9a97ad632d0825be1ece361936d1d0bdb5c7
$ git stash list
stash@{0}: Created via "git stash store".
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TLucas

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值