git笔记之在多个分支中复用某个分支提交的更改

git笔记之在多个分支中复用某个分支提交的更改

code review!

文章目录

1.实现该功能的 Bash 脚本示例

bash 复制代码
# 定义具体的提交哈希
commit_hash=<commit-hash>

# 定义目标分支
branches=("branch1" "branch2" "branch3")

# 在每个目标分支上应用更改
for branch in "${branches[@]}"; do
  git checkout $branch
  git cherry-pick $commit_hash
  git push origin $branch
done

# 返回到最初的分支
git checkout source-branch

2.这个脚本是否可以处理新添加的文件?

这个脚本可以处理新添加的文件,但有一些注意事项:

  1. 新文件的处理git cherry-pick会尝试将指定的提交(包含新文件的提交)应用到目标分支上。如果新文件在目标分支中不存在,cherry-pick会将其添加。

  2. 冲突的处理 :如果目标分支中有与新文件同名的文件,或者其他更改导致冲突,cherry-pick会产生冲突,需要手动解决。

  3. 确保干净的工作区:在运行脚本之前,请确保工作树和索引中没有未提交的更改,以避免冲突或混乱。

因此,这个脚本可以应用包含新文件的提交,但在冲突的情况下需要额外的手动干预。

3.该脚本使用前,应先使用下述脚本重置本地仓库所有分支与远程保持一致,确保干净的工作区

bash 复制代码
#!/bin/bash

# 获取当前所在的分支
initial_branch=$(git rev-parse --abbrev-ref HEAD)

# 从远程拉取所有最新的信息
git fetch --all

# 获取所有的本地跟踪分支
branches=($(git branch -r | grep -v '\->' | while read remote; do echo ${remote#origin/}; done))

# 遍历每个分支
for branch in "${branches[@]}"; do
  # 切换到该分支
  git checkout $branch || { echo "无法切换到分支: $branch"; continue; }
  
  # 从远程拉取最新代码并强制更新
  git reset --hard origin/$branch
  git clean -fd
  
  # 输出信息
  echo "分支 $branch 已重置为与远程保持一致。"
done

# 返回到最初的分支
git checkout $initial_branch

4.git cherry-pick的含义

git cherry-pick 是一个 Git 命令,用于将某个提交(或多个提交)的更改从一个分支复制到另一个分支。它的主要用途是选择性地应用特定的提交,而不需要合并整个分支。

用法

bash 复制代码
git cherry-pick <commit-hash>

主要特点

  • 选择性应用:只应用指定的提交,不影响其他提交。
  • 有助于修复问题:快速将 bug 修复从一个分支移植到另一个分支。
  • 冲突处理:如果存在冲突,需要手动解决并继续。

示例

  1. 在分支 A 上进行更改并提交

    bash 复制代码
    git checkout A
    # 做一些更改
    git commit -m "Fix issue #123"
  2. 切换到分支 B 并应用提交

    bash 复制代码
    git checkout B
    git cherry-pick <commit-hash>

这样,分支 B 就会包含在 A 上的特定更改。

相关推荐
wan5555cn3 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
雁于飞5 小时前
vscode中使用git、githup的基操
笔记·git·vscode·学习·elasticsearch·gitee·github
rannn_1115 小时前
【Javaweb学习|实训总结|Week1】html基础,CSS(选择器、常用样式、盒子模型、弹性盒布局、CSS定位、动画),js(基本类型、运算符典例)
css·笔记·学习·html
Ro Jace5 小时前
心灵笔记:第一性原理学习与实践
笔记
aramae7 小时前
C++ -- 模板
开发语言·c++·笔记·其他
小马学嵌入式~7 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
hour_go7 小时前
用户态与内核态的深度解析:安全、效率与优化之道
笔记·操作系统
摇滚侠9 小时前
Vue3入门到实战,最新版vue3+TypeScript前端开发教程,笔记03
javascript·笔记·typescript
岑梓铭10 小时前
考研408《计算机组成原理》复习笔记,第六章(1)——总线概念
笔记·考研·408·计算机组成原理·计组
Suckerbin10 小时前
digitalworld.local: TORMENT
笔记·安全·web安全·网络安全