国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table of Contents
git-rebase
git-merge
git-rebase 與 git-merge 的差異
Advantages and disadvantages of using git-rebase to merge
Should I use git-rebase or git-merge?
git-merge Pai
git-rebase sent
Personal subjective opinion
Home Development Tools git What do git-rebase and git-merge do? What's the difference?

What do git-rebase and git-merge do? What's the difference?

Jul 15, 2022 am 10:36 AM
git github

What do git-rebase and git-merge do? What is the difference between git-rebase and git-merge? The following article will introduce to you the difference between git-rebase and git-merge. I hope it will be helpful to you!

What do git-rebase and git-merge do? What's the difference?

Using Git for version control should be one of the workflows that most engineers encounter every day, but what I use is nothing more than push, pull, merge, checkout or log and other instructions. If you go more in-depth, you won’t know anything about it. During the interview was asked this question: "Do you know the difference between Git's merge and rebase?"

I was immediately confused after listening to it. To me, rebase is a tool used to organize commits, and it actually works. Compare with merge? [Recommended study: "Git Tutorial"]

git-rebase

Let me first talk about what I usually use the rebase command for. , if I add a new unit test and then commit, then log will have an additional record of commit:

What do git-rebase and git-merge do? Whats the difference?

But after committing, I discovered that I had missed writing another test case, so after making up for it, I committed again:

What do git-rebase and git-merge do? Whats the difference?

At this time, there will be another commit in the record, but for me, these two commit are actually doing the same thing, so before pushing to remote, You will want to sort out the commits first and merge the two records.

There are two ways to merge these two records. The first is to reset before adding the first test case, and then do it directly commit . The second method is to use rebase to handle it!

First let us take a look at the current log:

What do git-rebase and git-merge do? Whats the difference?

My purpose is to combine 9dc67ff and 87af945 Organized into one, so the commits to be adjusted are from init, that is, all the commits after the commit id is 7eb57cb. If combined with the rebase command, it will be:

git?rebase?-i?7eb57cb

After typing, you will jump to the vim editing screen:

What do git-rebase and git-merge do? Whats the difference?

You will see all the commits after 7eb57cb (currently only 9dc67ff and 87af945), then change the pick of 9dc67ff to squash, which means merging it with the previous commit . Click i first and then start editing the content with vim:

What do git-rebase and git-merge do? Whats the difference?

After editing, you can click esc and enter :wq to save, if you are just curious, come in Play and have a look. If you don’t want to save, just enter :q!. After completing the above process, check the log again and you will find that the two commits have become one. After saving, you will jump to the commit message screen. Here you can enter the merged commit message, but I will not change it and save it directly:

What do git-rebase and git-merge do? Whats the difference?

End above After the process, check the log again, and you will find that two commits have become one:

What do git-rebase and git-merge do? Whats the difference?

Nice first, the above operation is the interactive mode of rebase, in git rebase The -i entered later is actually the abbreviation of interactive.

git-merge

Everyone should be very familiar with the merge command, because when doing new features, you usually pull out a branch and then merge Return to the main branch such as master or develop. The operation process is as follows:

What do git-rebase and git-merge do? Whats the difference?

在 merge 的時候會有兩種情況,第一種是 ?fast-forward,會把被合并分支的 HEAD 的 reference 移到要合併分支內(nèi)最新的 commit 上,上方操作的 merge 結(jié)果就是 fast-forward,master 的 HEAD 被移到 string-library 的最新 commit,畫成圖的話就是這樣子:

What do git-rebase and git-merge do? Whats the difference?

但是如果在執(zhí)行 merge 的時候產(chǎn)生沖突,那分支的合并行為就會和 fast-forward 有點不同了。舉例來說,我分別在 master 和 string-library 的同一個文件添加內(nèi)容,那當(dāng)我執(zhí)行 merge 的時候就會要求先修復(fù)沖突:

What do git-rebase and git-merge do? Whats the difference?

修復(fù)完后,再執(zhí)行 commit 完成合并,而這一次合并時,會再多一個 commit 是有關(guān) merge 了 string-library 分支的紀(jì)錄:

What do git-rebase and git-merge do? Whats the difference?

這個情況畫成圖就會像這樣子:

What do git-rebase and git-merge do? Whats the difference?

git-rebase 與 git-merge 的差異

看完上方對 rebasemerge 的介紹后,你也許會想說:

「咦?那這兩個不是完全不同的東西嗎?」

對的,原本我也是這麼認(rèn)為,一直到我去看了 git-rebase 的文檔,才發(fā)現(xiàn)原來我一直誤會它了。在 git book 的 rebase 篇章,第一段就說明了,在 Git 里有兩種方法可以用來整合兩個分支,而這兩個在上方都有提到,分別為 mergerebase

What do git-rebase and git-merge do? Whats the difference?

從上方的 merge 例子已經(jīng)知道了,merge 在合并的時候會有 fast-forward,和沖突時用一個 commit 記錄合并變更的兩種情形。而 rebase 的整合方式非常有趣,依照關(guān)于 rebase 的另一段說明,它可以「把某個分支中所有 commit 的過程,以另一個分支的 commit 為基礎(chǔ)重播一遍」:

What do git-rebase and git-merge do? Whats the difference?

這是什麼意思呢?首先讓我們回到上述的例子,并在 master 分支上用 reset,讓 master 的版本回到合并 string-library 之前:

What do git-rebase and git-merge do? Whats the difference?

現(xiàn)在我們要用 rebase 指令,將 string-library 所有的 commit 修改,以 master 的 commit 為基礎(chǔ)跑一次。使用 rebase 合并的第一步,要先切到想重播 commit 的分支:

git?checkout?string-library

然后再輸入 git rebase 指令,并于后方指定要在哪個分支上重播:

git?rebase?master

執(zhí)行結(jié)果:

What do git-rebase and git-merge do? Whats the difference?

在 rebase 重播 commit 的過程中,和 merge 相似的地方在于,如果有沖突的話還是需要解決,但在解決后,并不是使用 commit 指令進(jìn)行合并,而是要輸入 git rebase --continue,讓 rebase 可以繼續(xù)重播接下來的 commit:

What do git-rebase and git-merge do? Whats the difference?

重播完成時,會顯示目前重播到哪個 commit,以 string-library 來說就是最新的add string unit test D。這時候的分支關(guān)系,畫成圖就會變成:

What do git-rebase and git-merge do? Whats the difference?

上圖在經(jīng)過 rebase 之后,string-library 里 07e38fb 修改,會以 master 的 commit 為基底再重播一次。

需要注意的是,重播后的 commit id 會和原本的不一樣,這等于完全改寫了分支內(nèi)所有的 commit 歷史紀(jì)錄。

In addition, after executing the rebase, string-library has not actually been merged back to the master branch, so it is still necessary to switch back to the master and execute merge to complete the merge:

What do git-rebase and git-merge do? Whats the difference?

Because rebase has been used to handle the commit conflicts during replay, now the merge will go directly to the fast-forward merge, and there will not be another commit record for the merge.

Advantages and disadvantages of using git-rebase to merge

Advantages

  • No redundant commits will be generated during the merge.

  • Conflicts can be handled in commit units during replay.

  • When merging, it will be arranged according to the commit of the branch, so that the review issue or feature processing process can be clearly understood. If you use merge, the commits of the two branches will be arranged in chronological order after the merge.

  • When contributing to an open source project, if you rebase before pushing, the author can directly merge in a fast-forward manner without the need to resolve conflicts separately.

Disadvantages

The biggest disadvantage is the one mentioned above. Using rebase will modify the history of commits. If you organize commits or branches locally, that's fine. , but if you accidentally change the remote branch, and then accidentally use git push -f, you may be hated by your colleagues, or you may be submitted to a purely northern engineer.

Should I use git-rebase or git-merge?

After checking some information, I found that both rebase and merge have their own supporters. I will first explain their ideas and then subjectively mention my own opinions.

git-merge Pai

Supportgit-merge Pai’s engineers believe that the value of version records lies in project commits. That is, "what actually happened in the history of this project". If you modify these historical records, it will be very bad. So even though the contents of different branches are mixed together after the merge, they still illustrate the history of the project.

git-rebase sent

supportgit-rebase The engineers sent felt that commit was talking about the "evolution process" of the project. What happened is important. Even if the commit history is modified, what happened remains unchanged. Since you can use a clearer and more concise record for future generations to read, you should do so.

Personal subjective opinion

I personally still use git-rebase to modify commits to make the history records simpler and easier to read, but the use is limited to push to remote Previously, if I had pushed the records to remote today, I would not modify them no matter how messy they were. After all, the remote records were shared by everyone. If I did not modify them at will, I would respect other members of the team.

[Related video tutorial recommendations: web front-end]

The above is the detailed content of What do git-rebase and git-merge do? What's the difference?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The first tutorial to open pycharm is a must-see setup guide for the first time The first tutorial to open pycharm is a must-see setup guide for the first time May 23, 2025 pm 10:48 PM

When you open PyCharm for the first time, you should first create a new project and select a virtual environment, and then be familiar with the editor area, toolbar, navigation bar, and status bar. Set up Darcula themes and Consolas fonts, use smart tips and debugging tools to get more efficient, and learn Git integration.

How to verify social security number string in PHP? How to verify social security number string in PHP? May 23, 2025 pm 08:21 PM

Social security number verification is implemented in PHP through regular expressions and simple logic. 1) Use regular expressions to clean the input and remove non-numeric characters. 2) Check whether the string length is 18 bits. 3) Calculate and verify the check bit to ensure that it matches the last bit of the input.

How to use graphical tools to compare version differences in git How to use graphical tools to compare version differences in git May 22, 2025 pm 10:48 PM

The steps to effectively use graphical tools to compare the differences in Git versions include: 1. Open GitKraken and load the repository, 2. Select the version to compare, 3. View the differences, and 4. In-depth analysis. Graphical tools such as GitKraken provide intuitive interfaces and rich features to help developers understand the evolution of code more deeply.

Gitstatus In-depth analysis of viewing repository status Gitstatus In-depth analysis of viewing repository status May 22, 2025 pm 10:54 PM

The gitstatus command is used to display the status of the working directory and temporary storage area. 1. It will check the current branch, 2. Compare the working directory and the temporary storage area, 3. Compare the temporary storage area and the last commit, 4. Check untracked files to help developers understand the state of the warehouse and ensure that there are no omissions before committing.

Configure VSCode and GitHub for code synchronization Configure VSCode and GitHub for code synchronization May 20, 2025 pm 06:33 PM

Configuring VSCode to synchronize code with GitHub can improve development efficiency and team collaboration. First, install the "GitHubPullRequestsandIssues" and "GitLens" plugins; second, configure the GitHub account; then clone or create a repository; finally, submit and push the code to GitHub.

How to develop a complete Python Web application? How to develop a complete Python Web application? May 23, 2025 pm 10:39 PM

To develop a complete Python Web application, follow these steps: 1. Choose the appropriate framework, such as Django or Flask. 2. Integrate databases and use ORMs such as SQLAlchemy. 3. Design the front-end and use Vue or React. 4. Perform the test, use pytest or unittest. 5. Deploy applications, use Docker and platforms such as Heroku or AWS. Through these steps, powerful and efficient web applications can be built.

How to verify IMEISV strings in PHP? How to verify IMEISV strings in PHP? May 28, 2025 pm 03:39 PM

Verifying an IMEISV string in PHP requires the following steps: 1. Verify the 16-bit numeric format using regular expressions. 2. Verify the validity of the IMEI part through the Luhn algorithm. 3. Check the validity of the software version number. The complete verification process includes format verification, Luhn checking and software version number checking to ensure the validity of IMEISV.

How to create and delete tags on remote repository How to create and delete tags on remote repository May 22, 2025 pm 10:33 PM

Create tags on remote repository using gitpushorigin, delete tags using gitpushorigin--delete. The specific steps include: 1. Create a local tag: gittagv1.0. 2. Push to remote: gitpushoriginv1.0. 3. Delete local tag: gittag-dv1.0. 4. Delete remote tag: gitpushorigin--deletev1.0.

See all articles