【Git】解决分支冲突、分支合并、版本回退、版本管理

解决本地冲突

1. 合并分支

假设你正在 main 分支上,想要合并 feature 分支。

bash 复制代码
git checkout main
git merge feature

如果两个分支都对同一文件做了不同的修改,Git 会提示你有冲突,并显示冲突文件。

2. 查看冲突文件

使用以下命令查看冲突状态:

bash 复制代码
git status

输出中会显示"unmerged paths",并列出冲突的文件。

3. 手动解决冲突

打开冲突文件,查找冲突标记:

plaintext 复制代码
<<<<<<< HEAD
当前分支的内容
=======
合并分支的内容
>>>>>>> feature

选择合适的内容,删除标记后保存文件。

4. 标记冲突已解决

使用以下命令将已解决的文件添加到暂存区:

bash 复制代码
git add <冲突文件名>
5. 提交合并

完成合并后,提交更改:

bash 复制代码
git commit -m "Resolved merge conflict between main and feature"

解决远程冲突

1. 拉取远程更新

当你从远程仓库拉取更改时,如果本地也有未提交的更改,可能会出现冲突。

bash 复制代码
git pull origin main

如果有冲突,Git 会提示并显示冲突文件。

2. 查看冲突文件

同样使用:

bash 复制代码
git status
3. 手动解决冲突

和本地冲突一样,打开冲突文件,解决冲突标记。

4. 标记冲突已解决

添加已解决的文件:

bash 复制代码
git add <冲突文件名>
5. 提交更改

提交合并:

bash 复制代码
git commit -m "Resolved merge conflict after pulling from remote"
6. 推送更改到远程

最后,将更改推送到远程仓库:

bash 复制代码
git push origin main

总结

无论是本地冲突还是远程冲突,步骤都是类似的。主要是:

  1. 尝试合并或拉取更改。
  2. 检查冲突文件。
  3. 手动解决冲突。
  4. 标记解决后的文件并提交。

2. 分支合并

合并命令:
bash 复制代码
git checkout main
git merge feature
  • 如果不需要保留历史

    bash 复制代码
    git merge --squash feature

3. 版本回退

回退到某个提交:
  1. 查看提交历史

    bash 复制代码
    git log --oneline
  2. 选择提交后回退

    bash 复制代码
    git reset --hard <commit_hash>  # 永久回退

    或者

    bash 复制代码
    git reset --soft <commit_hash>  # 保留文件变更
使用 revert
bash 复制代码
git revert <commit_hash>  # 创建一个新的提交来撤销某个提交

4. 版本管理

查看提交历史:
bash 复制代码
git log --oneline --graph
创建标签:
bash 复制代码
git tag -a v1.0 -m "Version 1.0"
推送标签到远程:
bash 复制代码
git push origin v1.0

5. 删除分支

删除本地分支:
bash 复制代码
git branch -d feature  # 删除已合并的分支
git branch -D feature  # 强制删除未合并的分支
删除远程分支:
bash 复制代码
git push origin --delete feature
相关推荐
SEO_juper16 分钟前
Semrush 蓝海关键词筛选,AI 一键拓展完整词库
大数据·谷歌·seo·geo·gemini·询盘·b2b
阿 才2 小时前
跟文件系统(busybox)的构建
大数据·hadoop·分布式
宁波鹿语心理2 小时前
过度卷入的三角化:养育者情感投射对青少年自我边界形成的结构性影响及干预路径
大数据
逐米时代2 小时前
制造型企业AI智能体实施步骤详解:提升协同效率的实战指南
大数据·人工智能
大嘴皮猴儿3 小时前
跨境电商运营笔记:我是如何用工具解决多语言素材问题的
大数据·人工智能·新媒体运营·自动翻译·教育电商
赤龙ERP3 小时前
赤龙一周观察 · 6月第2周
大数据·人工智能·ai·erp
JGDT_3 小时前
ERP重塑与未来趋势:SAP的实践及大一统格局(上)
大数据·人工智能·安全·架构·开源
ACP广源盛139246256734 小时前
IX7008 PCIe 交换芯片@ACP#RTX Spark 经济型 8 口扩展芯片(对比 ASM1806)
大数据·人工智能·分布式·嵌入式硬件·gpt·spark·电脑
lauo4 小时前
碳基心脏最后的堡垒——ibbot青春版:你的随身Token生产厂
大数据·人工智能·chatgpt·智能手机·ai-native
TDengine (老段)4 小时前
TDengine 扫描算子 — TableScan、TagScan 与下推优化
大数据·数据库·物联网·时序数据库·tdengine·涛思数据