検索
ホームページ開発ツールGitgit バージョン管理のブランチ操作を要約して整理する

この記事では、Git に関する関連知識を提供し、主にバージョン管理におけるブランチの作成、削除、表示、マージに関する問題を紹介します。

git バージョン管理のブランチ操作を要約して整理する

推奨学習: 「Git 学習チュートリアル

1 ブランチの基本概念

単一ブランチ:

最初、master ブランチは行です。Git は master を使用して最新の送信をポイントし、次に HEAD を使用してポイントします。 master に、現在のブランチと現在のブランチのサブミット ポイントを決定できます:

git バージョン管理のブランチ操作を要約して整理する

サブミットするたびに、master ブランチは前進します。 1 ステップなので、送信を続けると、master ブランチの行がどんどん長くなっていきます。

複数のブランチ:

dev などの新しいブランチを作成すると、Git は ## を指す dev という新しいポインターを作成します。 # master と同じコミットを行い、HEADdev にポイントします。これは、現在のブランチが dev

にあることを意味します。 Git によるブランチの作成は非常に高速です。

dev ポインターの追加と HEAD ポインターの変更を除いて、ワークスペース内のファイルは変更されないためです。

git バージョン管理のブランチ操作を要約して整理する

ただし、これ以降、ワークスペースへの変更と送信は

dev ブランチに対して行われます。たとえば、新しい送信の後、dev ポインタは 1 ステップ進みますが、master ポインタは変更されません:

git バージョン管理のブランチ操作を要約して整理する マルチブランチ マージ:

ポイント マスターdev の現在のコミットに追加すると、マージが完了し、Git はブランチを非常に迅速にマージします。ポインタを変更するだけで、ワークスペースの内容は変更されません。

git バージョン管理のブランチ操作を要約して整理する

ブランチをマージした後、dev ブランチを削除することもできます。 dev ブランチを削除すると、dev ポインタが削除されます。削除後は、master ブランチが残ります:

git バージョン管理のブランチ操作を要約して整理する

2 ブランチ管理

2.1 ブランチの作成

    は、
  • git checkout:
$ git checkout -b dev
Switched to a new branch 'dev'
git checkout コマンドと -b パラメーターを使用して作成および切り替えを行います。これは、次の 2 つのコマンドと同等です。

$ git branch dev
$ git checkout dev
Switched to branch 'dev'
  • git switch:
を使用して、新しい dev ブランチを作成して切り替えます。

$ git switch -c dev
# を使用できます。 # #注:

git switch
git checkout はブランチ操作にまったく同じように使用されます。そうすれば、ブランチ操作に可能な限り git Branchgit switch を使用できるようになります。 なぜなら git checkout
ブランチの操作に加えて、ファイルの操作もできます (ワークスペースを書き換えることもできます)。

2.2 ブランチの表示
$ git branch
* dev
  master

2.3 ブランチのマージ

git merge

コマンド: 指定されたブランチを現在のブランチにマージするために使用されます。 <pre class="brush:php;toolbar:false"># 切换回当前的分支:$ git checkout master Switched to branch 'master'# 合并到指定分支:$ git merge dev Updating 599dbdb..4aac6c7 Fast-forward  readme.txt | 1 + 1 file changed, 1 insertion(+)</pre>上記では早送りモード (「早送りモード」) を使用していますが、このモードではブランチを削除するとブランチ情報が失われます。

早送りモード

を強制的に無効にしたい場合は、Git はマージ中に新しいコミットを生成し、ブランチ履歴からブランチ情報を確認できるようにします。

$ git merge --no-ff -m "merge with no-ff" dev
Merge made by the 'recursive' strategy.
 readme.txt | 1 + 1 file changed, 1 insertion(+)
マージ結果は次のとおりです:


2.4 ブランチを削除しますgit バージョン管理のブランチ操作を要約して整理する

$ git branch -d dev
Deleted branch dev (was 4aac6c7).
3 マージ競合を解決します

競合状況が発生します以下の図に示すように、Git は「クイック マージ」を実行できないため、コミットする前に競合を手動で解決する必要があります。

マージ競合後の結果:
git バージョン管理のブランチ操作を要約して整理する

3.1 git 公式 Web サイトで解決しますgit バージョン管理のブランチ操作を要約して整理する

Click

Merge request

、必要なブランチ コンテンツを選択し、[マージ] を選択します。


3.2 ローカル ソリューションgit バージョン管理のブランチ操作を要約して整理する

ステップ 1. マージに使用されるブランチをプルして確認します

    git fetch origingit checkout -b "feature1" "origin/feature1"
  • ステップ 2ローカルで表示して変更を行う
    • Git using
    • >> ; >>>>
    次のようなさまざまなブランチのコンテンツをマークします:

    Git is a distributed version control system.
    Git is free software distributed under the GPL.
    Git has a mutable index called stage.
    Git tracks changes of files.>>>>>> feature1
    • 步骤三. 合并分支并解决冲突
    git fetch origingit checkout "master"git merge --no-ff "feature1"
    • 步骤四. 推送代码并合并
    git push origin "master"

    其他方法为:

    • 法1:

    保留本地最新修改,并拉取仓库中 的代码到本地

    git stash  
    git pull origin master  
    git stash pop
    • 法2:
      放弃本地代码,新修改的都不要了,退回上一版本,再拉取代码到本地
    git reset --hard  
    git pull origin master  
    
    # 或git fetch --allgit reset --hard origin/master 
    git pull

    4 分支转移

    git cherry-pick命令的作用,就是将指定的提交commit应用于其他分支。

    $ git cherry-pick \<commithash></commithash>

    上面命令就会将指定的提交commitHash,应用于当前分支。这会在当前分支产生一个新的提交,当然它们的哈希值会不一样。

    举例来说,代码仓库有masterfeature两个分支。

     a - b - c - d Master \\
     e - f - g Feature

    现在将提交f应用到master分支。

    \# 切换到 master 分支
    $ git checkout master\# Cherry pick 操作
    $ git cherry-pick f

    上面的操作完成以后,代码库就变成了下面的样子。

     a - b - c - d - f Master \\
     e - f - g Feature

    从上面可以看到,master分支的末尾增加了一个提交f。

    git cherry-pick命令的参数,不一定是提交的哈希值,分支名也是可以的,表示转移该分支的最新提交。

    $ git cherry-pick feature

    上面代码表示将feature分支的最近一次提交,转移到当前分支。

    Cherry pick 支持一次转移多个提交。

    $ git cherry-pick \<hasha> \<hashb></hashb></hasha>

    上面的命令将 AB 两个提交应用到当前分支。这会在当前分支生成两个对应的新提交。

    如果想要转移一系列的连续提交,可以使用下面的简便语法。

    $ git cherry-pick A..B

    上面的命令可以转移从 AB 的所有提交。它们必须按照正确的顺序放置:提交 A 必须早于提交 B,否则命令将失败,但不会报错。

    注意,使用上面的命令,提交 A 将不会包含在 Cherry pick 中。如果要包含提交 A,可以使用下面的语法。

    $ git cherry-pick A^..B
    `git cherry-pick`命令的常用配置项如下。
    
    #### -e,--edit
    
    打开外部编辑器,编辑提交信息。
    
    #### -n,--no-commit
    
    只更新工作区和暂存区,不产生新的提交。
    
    #### -x
    
    在提交信息的末尾追加一行`cherry picked from commit ...`,方便以后查到这个提交是如何产生的。
    
    #### -s,--signoff
    
    在提交信息的末尾追加一行操作者的签名,表示是谁进行了这个操作。
    
    #### -m parent-number,--mainline parent-number
    
    如果原始提交是一个合并节点,来自于两个分支的合并,那么 `Cherry pick` 默认将失败,因为它不知道应该采用哪个分支的代码变动。
    
    `-m`配置项告诉 Git,应该采用哪个分支的变动。它的参数`parent-number`是一个从1开始的整数,代表原始提交的父分支编号。
    
    ```bash
    $ git cherry-pick -m 1 \<commithash></commithash>

    上面命令表示,Cherry pick 采用提交commitHash来自编号1的父分支的变动。

    一般来说,1号父分支是接受变动的分支,2号父分支是作为变动来源的分支。

    如果操作过程中发生代码冲突,Cherry pick会停下来,让用户决定如何继续操作。

    (1)–continue

    用户解决代码冲突后,第一步将修改的文件重新加入暂存区(git add .),第二步使用下面的命令,让 Cherry pick 过程继续执行。

    $ git cherry-pick --continue

    (2)–abort

    发生代码冲突后,放弃合并,回到操作前的样子。

    (3)–quit

    发生代码冲突后,退出 Cherry pick,但是不回到操作前的样子。

    Cherry pick 也支持转移另一个代码库的提交,方法是先将该库加为远程仓库。

    转移另一个代码库的提交

    $ git remote add target git://gitUrl

    上面命令添加了一个远程仓库target

    然后,将远程代码抓取到本地。

    $ git fetch target

    上面命令将远程代码仓库抓取到本地。

    接着,检查一下要从远程仓库转移的提交,获取它的哈希值。

    $ git log target/master

    最后,使用git cherry-pick命令转移提交。

    $ git cherry-pick \<commithash></commithash>

    5 常用的分支

    在实际开发中,我们应该按照几个基本原则进行分支管理:

    首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

    其次,干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,并在master分支发布1.0版本;

    小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

    git バージョン管理のブランチ操作を要約して整理する

    5.1 bug分支

    在开发过程中,bug 就像家常便饭一样。有了 bug 就需要修复,在 Git 中,由于分支是如此的强大,所以,每个 bug 都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除。

    当你接到一个修复一个代号101的 bug 的任务时,很自然地,你想创建一个分支 issue-101 来修复它,但是,等等,当前正在dev上进行的工作还没有提交:

    $ git status
    On branch dev
    Changes to be committed: (use "git reset HEAD \<file>..." to unstage)
    
     new file: hello.py
    
    Changes not staged for commit: (use "git add \<file>..." to update what will be committed)
     (use "git checkout -- \<file>..." to discard changes in working directory)
    
     modified: readme.txt</file></file></file>

    并不是你不想提交,而是工作只进行到一半,还没法提交,预计完成还需1天时间。但是,必须在两个小时内修复该 bug,怎么办?

    幸好,Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作:

    $ git stash
    Saved working directory and index state WIP on dev: f52c633 add merge

    现在,用git status查看工作区,就是干净的(除非有没有被Git管理的文件),因此可以放心地创建分支来修复 bug。

    首先确定要在哪个分支上修复 bug,假定需要在master分支上修复,就从master创建临时分支:

    $ git checkout master
    Switched to branch 'master'Your branch is ahead of 'origin/master' by 6 commits. (use "git push" to publish your local commits)$ git checkout -b issue-101
    Switched to a new branch 'issue-101'

    现在修复bug,需要把“Git is free software …”改为“Git is a free software …”,然后提交:

    $ git add readme.txt 
    $ git commit -m "fix bug 101"[issue-101 8842ff5] fix bug 101
     1 file changed, 1 insertion(+), 1 deletion(-)

    修复完成后,切换到master分支,并完成合并,最后删除issue-101分支:

    $ git switch master
    Switched to branch 'master'Your branch is ahead of 'origin/master' by 6 commits. (use "git push" to publish your local commits)$ git merge --no-ff -m "merged bug fix 101" issue-101
    Merge made by the 'recursive' strategy.
     readme.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)

    太棒了,原计划两个小时的 bug 修复只花了5分钟!现在,是时候接着回到dev分支干活了!

    $ git switch dev
    Switched to branch 'dev'$ git status
    On branch dev
    nothing to commit, working tree clean

    工作区是干净的,刚才的工作现场存到哪去了?用git stash list命令看看:

    $ git stash list
    stash@{0}: WIP on dev: f52c633 add merge

    工作现场还在,Git 把stash内容存在某个地方了,但是需要恢复一下,有两个办法:

    一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;

    另一种方式是用git stash pop,恢复的同时把stash内容也删了:

    $ git stash pop
    On branch dev
    Changes to be committed: (use "git reset HEAD \<file>..." to unstage)
    
     new file: hello.py
    
    Changes not staged for commit: (use "git add \<file>..." to update what will be committed)
     (use "git checkout -- \<file>..." to discard changes in working directory)
    
     modified: readme.txt
    
    Dropped refs/stash@{0} (5d677e2ee266f39ea296182fb2354265b91b3b2a)</file></file></file>

    再用git stash list查看,就看不到任何stash内容了:

    $ git stash list

    你可以多次stash,恢复的时候,先用git stash list查看,然后恢复指定的stash,用命令:

    $ git stash apply stash@{0}

    master分支上修复了bug后,我们要想一想,dev分支是早期从master分支分出来的,所以,这个bug其实在当前dev分支上也存在。

    那怎么在dev分支上修复同样的bug?重复操作一次,提交不就行了?在 Git 中还有比这更简单的方法可以实现。

    同样的 bug,要在dev上修复,我们只需要把8842ff5 fix bug 101这个提交所做的修改“复制”到dev分支。注意:我们只想复制8842ff5 fix bug 101这个提交所做的修改,并不是把整个master分支merge过来。

    为了方便操作,Git 专门提供了一个cherry-pick命令,让我们能复制一个特定的提交到当前分支:

    $ git branch\* dev
     master
    $ git cherry-pick 8842ff5[dev 0944c8c] fix bug 101
     1 file changed, 1 insertion(+), 1 deletion(-)

    Git 自动给dev分支做了一次提交,注意这次提交的commit0944c8c,它并不同于master8842ff5,因为这两个commit只是改动相同,但确实是两个不同的commit。用git cherry-pick,我们就不需要在dev分支上手动再把修 bug 的过程重复一遍。

    有些聪明的童鞋会想了,既然可以在master分支上修复bug后,在dev分支上可以“重放”这个修复过程,那么直接在dev分支上修复 bug,然后在master分支上“重放”行不行?当然可以,不过你仍然需要git stash命令保存现场,才能从dev分支切换到master分支。

    5.2 feature分支

    在开发过程中,除了 bug 外,也还会有无穷无尽的新的功能要不断添加进来。

    添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。

    现在,你终于接到了一个新任务:开发代号为Vulcan的新功能,该功能计划用于下一代星际飞船。

    于是准备开发:

    $ git switch -c feature-vulcan
    Switched to a new branch 'feature-vulcan'

    5分钟后,开发完毕:

    $ git add vulcan.md
    
    $ git status
    On branch feature-vulcan
    Changes to be committed: (use "git reset HEAD \<file>..." to unstage)
    
     new file: vulcan.md
    
    $ git commit -m "add feature vulcan"[feature-vulcan d12cf23] add feature vulcan 1 file changed, 3 insertions(+)
     create mode 100644 vulcan.md</file>

    切回dev,准备合并:

    $ git switch dev

    一切顺利的话,feature分支和bug分支是类似的,合并,然后删除。

    但是!就在此时,接到上级命令,因经费不足,新功能必须取消!虽然白干了,但是这个包含机密资料的分支还是必须就地销毁:

    $ git branch -d feature-vulcan
    error: The branch 'feature-vulcan' is not fully merged.
    If you are sure you want to delete it, run 'git branch -D feature-vulcan'.

    销毁失败。Git 友情提醒,feature-vulcan分支还没有被合并,如果删除,将丢失掉修改,如果要强行删除,需要使用大写的-D参数。。

    现在我们强行删除:

    $ git branch -D feature-vulcan
    Deleted branch feature-vulcan (was d12cf23).

    终于删除成功!

    推荐学习:《Git教程

    以上がgit バージョン管理のブランチ操作を要約して整理するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

  • 声明
    この記事はCSDNで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
    git:ツール、github:サービスgit:ツール、github:サービスApr 24, 2025 am 12:01 AM

    GitとGithubは異なるツールです。Gitは分散バージョン制御システムであり、GithubはGitに基づくオンラインコラボレーションプラットフォームです。 GITは、ワークスペース、一時的な保管エリア、ローカルウェアハウスを介してコードを管理し、Gitinit、GitCloneなどの一般的なコマンドを使用します。Githubは、コードホスティング、プルリケスト、発行誘導などの機能を提供します。

    Git:バージョンコントロールのコア、Github:ソーシャルコーディングGit:バージョンコントロールのコア、Github:ソーシャルコーディングApr 23, 2025 am 12:04 AM

    GitとGithubは、最新のソフトウェア開発のための重要なツールです。 GITは、リポジトリ、ブランチ、コミット、マージを介してコードを管理するバージョン制御機能を提供します。 GitHubは、問題やPullRequestsなどのコードホスティングおよびコラボレーション機能を提供します。 GitとGithubを使用すると、開発効率とチームコラボレーション機能が大幅に向上する可能性があります。

    Git:バージョン制御システム、Github:ホスティングプラットフォームGit:バージョン制御システム、Github:ホスティングプラットフォームApr 22, 2025 am 12:02 AM

    Gitは2005年にLinus Torvazによって開発された分散バージョン制御システムであり、GitHubは2008年に設立されたGitベースのコードホスティングプラットフォームです。Gitは、スナップショット管理ファイルを介して分岐をサポートし、GitHubはチームコラボレーションを促進するためのプルリクエスト、問題追跡、コードレビュー機能を提供します。

    Git and Github:比較分析Git and Github:比較分析Apr 21, 2025 am 12:10 AM

    GitとGithubは、最新のソフトウェア開発における重要なツールです。 Gitは分散バージョン制御システムであり、GithubはGitベースのコードホスティングプラットフォームです。 GITのコア機能にはバージョン制御と支店管理が含まれ、GitHubはコラボレーションおよびプロジェクト管理ツールを提供します。 GITを使用する場合、開発者はファイルの変更を追跡して一緒に作業できます。 Githubを使用する場合、チームはPullRequestsや問題を介してコラボレーションできます。

    Github:コードホスティングプラットフォームの紹介Github:コードホスティングプラットフォームの紹介Apr 20, 2025 am 12:10 AM

    githubisubiscurucialforsoftedevelowmentdueToitsdueToitscompregeCosystemmanagementandcollaboration.itofferSversubactionsandPages.toolslikegithubactionsandpages.startbyMasteringBasicsLikeCreatingReapository、使用、および承認を使用します

    git and github:開発者にとって不可欠なツールgit and github:開発者にとって不可欠なツールApr 19, 2025 am 12:17 AM

    GitとGithubは、最新の開発者にとって不可欠なツールです。 1.バージョン制御にGitを使用します。並列開発のためのブランチを作成し、ブランチをマージし、エラーをロールバックします。 2。チームのコラボレーションにはGitHubを使用します:PullRequestを介したコードレビューでマージ競合を解決します。 3.実用的なヒントとベストプラクティス:定期的に送信し、メッセージを明確に送信し、.gitignoreを使用し、コードベースを定期的にバックアップします。

    Git and Github:彼らの関係は説明しましたGit and Github:彼らの関係は説明しましたApr 18, 2025 am 12:03 AM

    GitとGithubは同じものではありません。Gitは分散バージョン制御システムであり、GithubはGitに基づいたオンラインプラットフォームです。 GITは、開発者がコードバージョンを管理し、分岐、マージ、その他の機能を通じてコラボレーションを実現するのに役立ちます。 GitHubは、コードホスティング、レビュー、問題管理、ソーシャルインタラクション機能を提供し、GITのコラボレーション機能を強化します。

    Gitをダウンロードした後、何を設定する必要がありますかGitをダウンロードした後、何を設定する必要がありますかApr 17, 2025 pm 04:57 PM

    GITをインストールした後、より効率的に使用するには、次の設定が必要です。ユーザー情報の設定(名前とメールボックス)選択テキストエディターセット外部マージツールSSHキー設定を生成します。

    See all articles

    ホットAIツール

    Undresser.AI Undress

    Undresser.AI Undress

    リアルなヌード写真を作成する AI 搭載アプリ

    AI Clothes Remover

    AI Clothes Remover

    写真から衣服を削除するオンライン AI ツール。

    Undress AI Tool

    Undress AI Tool

    脱衣画像を無料で

    Clothoff.io

    Clothoff.io

    AI衣類リムーバー

    Video Face Swap

    Video Face Swap

    完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

    ホットツール

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    MantisBT

    MantisBT

    Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

    SublimeText3 Mac版

    SublimeText3 Mac版

    神レベルのコード編集ソフト(SublimeText3)

    VSCode Windows 64 ビットのダウンロード

    VSCode Windows 64 ビットのダウンロード

    Microsoft によって発売された無料で強力な IDE エディター

    SublimeText3 中国語版

    SublimeText3 中国語版

    中国語版、とても使いやすい