分支管理与冲突解决

Git Log 分析

  • 查看项目历史信息:
    • git log
typescript 复制代码
commit a1b2c3d4e5f67890abcdef1234567890abcdef12 (HEAD -> main, origin/main)
Author: 你的名字 <your@email.com>
Date:   Sun Mar 29 15:30:00 2026 +0800

    完成用户登录功能开发
    包含密码加密、表单验证、错误提示

commit 1234567890abcdef1234567890abcdef12345678
Author: 你的名字 <your@email.com>
Date:   Sat Mar 28 14:20:00 2026 +0800

    添加用户数据库模型与表结构

commit fedcba0987654321fedcba0987654321fedcba09
Author: 你的名字 <your@email.com>
Date:   Fri Mar 27 10:15:00 2026 +0800

    初始化项目结构,创建基础目录

commit 9876543210fedcba9876543210fedcba98765432
Author: 你的名字 <your@email.com>
Date:   Thu Mar 26 09:00:00 2026 +0800

    首次提交:创建 README.md 与 .gitignore
  • 筛选时间:
    • git log --since='2026-03-29 00:00:00'
typescript 复制代码
 commit a1b2c3d4e5f67890abcdef1234567890abcdef12 (HEAD -> main)
Author: test1 <test1@example.com>
Date:   Sun Mar 29 10:20:15 2026 +0800

    修复登录接口超时问题

commit 789abcd1234fe56cdef789abcdef123456789abc
Author: test2 <test2@example.com>
Date:   Sun Mar 29 09:10:30 2026 +0800

    优化页面加载速度
  • 筛选作者:
    • git log --author='test1'
typescript 复制代码
commit a1b2c3d4e5f67890abcdef1234567890abcdef12 (HEAD -> main)
Author: test1 <test1@example.com>
Date:   Sun Mar 29 10:20:15 2026 +0800

    修复登录接口超时问题

commit 456def789abc123456789abcdef123456789abcd
Author: test1 <test1@example.com>
Date:   Fri Mar 27 16:40:20 2026 +0800

    添加用户信息校验逻辑
  • 筛选描述:
    • git log --grep='test1'
typescript 复制代码
commit 1234567890abcdef1234567890abcdef12345678
Author: admin <admin@example.com>
Date:   Sat Mar 28 14:30:00 2026 +0800

    test1 模块:完成数据查询接口开发

commit 987654321fedcba987654321fedcba9876543210
Author: test1 <test1@example.com>
Date:   Thu Mar 26 11:20:10 2026 +0800

    初始化 test1 相关配置文件

分支管理

  • 概念:
    • 每次提交,Git 都把它们串成一条时间线,这条时间线就是一个分支。
  • 价值:
    • 多人协作。
    • 环境管理。

创建分支

  • 新建分支,但仍然停留在当前分支:
    • git branch 分支名
  • 新建分支并直接切换至该分支:
    • git checkout -b 分支名
typescript 复制代码
git_demo % git branch test1

git_demo % git checkout -b test2
Switched to a new branch 'test2'

查看分支

  • 列出所有本地分支:
    • git branch
  • 列出所有远程分支:
    • git branch -r
  • 列出所有本地与远程分支:
    • git branch -a
typescript 复制代码
git_demo % git branch
  test1
* test2
  master

git_demo % git branch -r
  origin/master

git_demo % git branch -a
  test1
* test2
  master
  remotes/origin/master

切换分支

  • 切换到指定分支:
    • git checkout 分支名
typescript 复制代码
git_demo % git checkout test1
Switched to branch 'test1'

删除分支

  • 删除指定分支:
    • git branch -d 分支名
typescript 复制代码
git_demo % git branch -d test1
Deleted branch test1 (was 0ba4asd).

分支合并应用场景

  • 合入主分支。

  • 主分支合并其他分支:

    • 通常使用 Merge Request 的方式。
  • 合并指定分支到当前分支:

    • git merge 其他分支 本分支
  • 变基:重新设置基准:

    • git rebase 其他分支

什么是冲突

  • 冲突:在并行工作的模式下,工作最终会发生重叠。当多个成员以不同的方式更改同一行内容时,在这种情况下,Git 无法判断哪个版本是正确的,这时就会产生冲突。
  • 冲突场景:
    • 多个分支代码合并到一个分支时。
    • 多个分支向同一个远端分支推送代码时。
typescript 复制代码
$ git merge change_site
Auto-merging filename
CONFLICT (content): Merge conflict in filename
Automatic merge failed; fix conflicts and then commit the result.

解决冲突

  • 解决冲突方式:
    • IDE 中解决冲突:选择要保留的内容点击 Accept,保存代码。
    • 文件中解决冲突:保留需要的内容,删除其余内容,去掉分割线,保存代码。
  • 冲突解决流程:
    • 在本地当前分支上,修改冲突内容。
    • 执行 git add . 添加到暂存区。
    • 执行 git commit -m '提交说明' 提交到本地仓库,完成合并。
    • 执行 git push 提交到远程仓库。
typescript 复制代码
<<<<<<<
(本地修改内容)
=======
(远程修改内容)
>>>>>>>
相关推荐
wuxinyan12331 分钟前
工业级大模型学习之路030:Streamlit 企业级智能体前端工作台
前端·学习·streamlit·智能体
长安紫薯1 小时前
学习AI日记
学习
星恒随风2 小时前
C语言数据结构排序算法详解(下):冒泡排序、快速排序、归并排序和计数排序
c语言·数据结构·笔记·学习·排序算法
NagatoYukee2 小时前
Spring Security基础部分学习
java·学习·spring
米小葱2 小时前
【学习笔记】cmake
笔记·学习
辰海Coding3 小时前
MiniSpring框架学习-分解 Dispatcher
java·学习·spring·架构
初夏睡觉3 小时前
数据结构学习之~二叉堆 (P3378 【模版】堆)
数据结构·c++·学习
z200509304 小时前
【Linux学习】Linux中的进程程序替换
linux·服务器·学习
小+不通文墨4 小时前
把树莓派外接的DHT11接收的温湿度发送到emqx上
经验分享·笔记·嵌入式硬件·学习·树莓派