Git creates branches from Master or Dev?
When we use Git to manage code, branching is a very important concept. Using branches can ensure the stability of the code while developing, and can also facilitate team collaboration. But when creating a branch, a very common question is: Should you create a new branch from the Master branch or the Dev branch?
In this article, we will explore this issue, understand which branch should be created from, and why.
First of all, we need to understand the role of the Master branch and the Dev branch. The Master branch is the main branch of Git and the most stable branch. Code on the Master branch should be deployable and should not contain any untested or incomplete features. This ensures the stability and security of the production environment.
The Dev branch, as the development branch of Git, is an environment used to develop new features or fix bugs. The code on the Dev branch may not necessarily be stable, but it should be fully functional and tested code. The Dev branch also facilitates team collaboration because each developer can create their own branch on it to perform relatively independent development work.
Next, let's consider which branch should serve as the basis for the new branch. Generally, we should create new branches from the Dev branch. This is because the new branch created from the Dev branch contains all the latest code and features, and these features have also been tested.
However, in some cases, it also makes sense to branch from the Master branch. For example, if we need to create a branch to fix a bug, we can create a new branch from the Master branch. This is because the branch where the bug is fixed should be built based on the code that has been released to the production environment, that is, the code on the Master branch.
Also, if we are not sure which branch to create a new branch from, we can consider creating a new branch from the latest shared branch (such as the latest merge request). This ensures that we build new branches based on the latest shared code, reducing the chance of merge conflicts.
In summary, creating a new branch from the Dev branch is a better choice. This way we can build new branches based on the latest testable code, ensuring that our code has the latest functionality and stability. However, in some cases, it also makes sense to create a new branch from the Master branch, such as when fixing a bug. If we are not sure which branch to create a new branch from, we can consider creating a new branch from the latest shared branch.
In short, when creating a new branch, we should carefully consider and choose the correct branch to create. This ensures our code has the latest functionality and stability, while also improving team collaboration and the security of our production environment.
The above is the detailed content of Does git create a branch from master or dev?. For more information, please follow other related articles on the PHP Chinese website!

This article provides a guide to Git management, covering GUI tools (Sourcetree, GitKraken, etc.), essential commands (git init, git clone, git add, git commit, etc.), branch management best practices (feature branches, pull requests), and merge con

This article explains the difference between Git's commit and push commands. git commit saves changes locally, while git push uploads these committed changes to a remote repository. The article highlights the importance of understanding this distin

This guide explains how to push a single Git commit to a remote branch. It details using a temporary branch to isolate the commit, pushing this branch to the remote, and then optionally deleting the temporary branch. This method avoids conflicts and

This article addresses common Git commit failures. It details troubleshooting steps for issues like untracked files, unstaged changes, merge conflicts, and pre-commit hooks. Solutions and preventative measures are provided to ensure smoother Git wo

This article details methods for viewing Git commit content. It focuses on using git show to display commit messages, author info, and changes (diffs), git log -p for multiple commits' diffs, and cautions against directly checking out commits. Alt

This beginner's guide introduces Git, a version control system. It covers basic commands (init, add, commit, status, log, branch, checkout, merge, push, pull) and resolving merge conflicts. Best practices for efficient Git use, including clear comm

This article explains the distinct roles of git add and git commit in Git. git add stages changes, preparing them for inclusion in the next commit, while git commit saves the staged changes to the repository's history. This two-step process enables

This article introduces Git, a distributed version control system. It highlights Git's advantages over centralized systems, such as offline capabilities and efficient branching/merging for enhanced collaboration. The article also details learning r


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

WebStorm Mac version
Useful JavaScript development tools

Atom editor mac version download
The most popular open source editor

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
