git分支和冲突

本文介绍了Git中HEAD的概念,如何创建、查看、切换和删除分支,以及merge和rebase的合并策略。特别强调了在合并分支时可能遇到的冲突问题及其解决步骤。
摘要由CSDN通过智能技术生成

HEAD

是一个特殊的指针,它始终指向当前所在的分支的最新提交。HEAD 表示当前的工作目录和索引(暂存区)所在的位置,是当前分支的最新提交的引用。

创建分支

// 创建分支
   $git branch 分支名称

// 创建并切换分支
   $git checkout -b 分支名称
   $git switch -c 分支名称(git2.23版本后命令)

查看分支

// 查看所有本地分支,当前分支会有 * 标记
   $git branch 

// 查看所有远程分支
   $git branch -r

// 查看所有本地分支和远程分支
   $git branch -a

// 查看所有分支的最近提交
   $git show-branch

切换分支

   $git checkout 分支名称
   $git switch 分支名称(git2.23版本后命令)

删除分支

// 当前分支已经合并了该分支才能删
    $git branch -d 分支名称

// 强制删除,未合并也行
    $git branch -D 分支名称

// 删除远程分支
   $git push origin --delete 分支名字

合并分支merge

// 把分支a合并到当前分支
   $git merge 分支a

注意: 每次在切换分支前,一定要提交工作区的修改

因为git的分支必须指向一个commit,没有任何commit就没有任何分支

实现:bugFix和main主分支内容保持一致

// 1、确保当前在main主分支上

// 2、把bugFix的内容拿过来合并到主分支
    $git merge bugFix

// 3、切换到bugFix分支
    $git checkout bugFix

// 4、把主分支的内容拿过来合并到bugFix
    $git merge main

合并分支rebase

// 把当前分支合并到a上去
   $git rebase 分支a

// 合并提交:当你在一个分支上进行多次连续的小型提交时,你希望合并为一个更大的提交
   $git rebase -i

第一步:当前在bugFix主分支上

第二步:$git rebase main

第三步:$git checkout main

第四步:$git rebase bugFix

merge和rebase 的区别:

1、merge 创建一个新的合并提交来整合两个分支的更改,而rebase 将当前分支上的提交复制到目标分支上,并在目标分支上重新应用这些提交。

2、merge 不会改变原有的提交历史,而 rebase 会,所以使用时需要小心谨慎

3、merge 操作可以在任何时候进行,而 rebase 更适合在要合并的分支没有太多其他人提交的情况下使用,以避免破坏公共分支的提交历史。

冲突

当多个分支修改同一个文件后,合并分支的时候就会产生冲突。

冲突处理:

        1、定位产生冲突的文件 :$git status

        2、打开冲突文件的修改内容为最终正确的结果

        3、git add -A 和 git commit -m '注释' 提交即可

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值