JIYIK CN >

Current Location:Home > Learning > OPERATING SYSTEM > Git >

Git Cherry-Pick and Merge Workflow

Author:JIYIK Last Updated:2025/04/02 Views:

This article discusses the workflow of git cherry-pick and git merge commands. We use these two commands to integrate changes from one branch to another branch in the Git version control system.

However, some scenarios favor the use of one command over the other.


git cherry-pick command

git cherry-pickcommand is a useful Git utility that allows us to select arbitrary Git commits by reference and apply them to the current HEAD. We use this command to select a commit from one branch and apply it to another branch.

When should we use git cherry-pickthe command?

While useful, the git cherry-pick command is not always best practice. In some cases, the traditional git merge command is preferred.

Nonetheless, there are situations where we can find an ideal command. Let's discuss some.

Suppose you are working on a project with multiple branches. You make changes on one branch and later find out that you checked out in the wrong branch.

Since these changes don't belong to that branch, you can use git cherry-pickthe command to move the changes to the correct branch.

Note the commit hash, git checkoutswitch to the correct branch using the command, and then run cherry-pick as shown below.

$ git cherry-pick <commit-id>

git cherry-pickCommands are also ideal for team collaboration. Projects have shared code between front-end and back-end components.

One developer can use the git cherry-pick command to copy code from another developer.

We also use git cherry-pickthe command to fix bugs. Suppose you have started working on a new feature in your project and you discover an existing bug in the process.

You can create a commit that explicitly fixes the bug and cherry-pick it to the master branch. This command is also ideal for restoring lost commits.


git merge command

git mergeThe command is self-explanatory. It simply connects the commit histories of the two branches and creates a merge commit.

You can bring changes from your development branch into your master branch by merging the two. It is a non-destructive way to merge changes from one branch to another instead of the git rebase command.

Merging is very simple. All you need to do is switch to the branch you want to merge and run the command. Here is an example.

Assuming we have some commits in the develop branch that are relevant to the master branch, we can merge those changes into the master branch like this:

# Switch to the main branch
$ git checkout main
# Merge the two
$ git merge development

Difference between git cherry-pick and git merge

As we have seen, both commands are useful when integrating changes from one branch into another. However, the difference lies in how we use each command.

git cherry-pickThe command is great for sampling smaller subsets of a large Git repository. It comes in handy when you want to move specific commits between branches.

On the other hand, the git merge command is great for large numbers of commits. Cherry-picking twenty commits from one branch to another is not ideal.

git mergeCommands are more suitable for this scenario.

That said, each command has its pros and cons. Let’s discuss some.

The -m command reduces clutter in our repository, as opposed to git mergethe -m command git cherry-pick, which always introduces extraneous merge commits.

On the other hand, using the git cherry-pick command can lead to duplicate commits and confuse other developers, especially if you have a shared Git repository.

git mergeThe command will help you integrate changes faster, especially when working with many commits. The downside of this commit is that you may encounter merge conflicts.

git cherry-pickOf course, you may encounter merge conflicts using the command, but with git mergethe command, the more commits you make, the more likely you are to encounter conflicts.

git mergeThe git merge and git cherry-pickgit commands are useful when merging changes from one branch to another in Git . The difference lies in when and how to use each command.

For reprinting, please send an email to 1244347461@qq.com for approval. After obtaining the author's consent, kindly include the source as a link.

Article URL:

Related Articles

Git merge development branch into feature branch

Publish Date:2025/04/02 Views:126 Category:Git

Creating new branches and merging them is considered to be the most powerful tool of Git. The ability of Git to create new branches and merge them into the development code is very useful for developers working in a team environment. This f

Recovering a conflicting Git merge

Publish Date:2025/04/02 Views:160 Category:Git

This article explains the revert command when a merge conflict occurs git merge . We will also take a quick look at how to undo a git merge that was successful and has been pushed to a remote repository. Recovering a conflicting Git merge I

Git merge test run

Publish Date:2025/04/02 Views:102 Category:Git

This article will discuss resolving git merge conflicts through git commands. Overview Git has many features which developers can use easily and solve their problems. Among these features of git, merging is the basic aspect that every devel

Using theirs option in Git merge

Publish Date:2025/03/31 Views:68 Category:Git

When developing software using Git, you can create different branches for different functions, but conflicts may exist between different branches. This article will explain how to use the command with theirs the -c option git merge to resol

Aborting a Git Merge

Publish Date:2025/03/31 Views:129 Category:Git

For example, Mario wants to pull the latest changes from the remote repository save-princess into a repository called . Mario uses git pull origin branch1 , but because the locally changed files are modified in Luigi the remote repository ,

Git merge-base 确定两个分支最近的共同祖先

Publish Date:2023/03/30 Views:262 Category:Git

本文说明了我们如何使用 git merge-base 命令在 Git 中找到最近的共同祖先提交。 当您创建一个分支或将一个分支合并到另一个分支时,这会派上用场。

Git merge 试运行

Publish Date:2023/03/30 Views:146 Category:Git

本文将讨论通过 git 命令解决 git merge 冲突。Git 有许多功能,开发人员可以轻松使用并解决他们的问题。 在 git 的这些功能中,合并是每个开发人员在大型团队中处理单个项目时都需要的基本方

Git Cherry-Pick 与合并工作流

Publish Date:2023/03/30 Views:237 Category:Git

本文讨论 git cherry-pick 和 git merge 命令的工作流程。 我们使用这两个命令将更改从一个分支集成到 Git 版本控制系统中的另一个分支。

Scan to Read All Tech Tutorials

Social Media
  • https://www.github.com/onmpw
  • qq:1244347461

Recommended

Tags

Scan the Code
Easier Access Tutorial