Git分支(副本)

版本控制过程需要同时推进多个任务,此时可以每个任务创建单独分支即开一个一模一样的副本 ,最终分支开发完后再合并到主分支提高开发效率

分支和文件版本的概念: 一个分支对应多个文件版本,默认指向最后更新的那个文件版本

使用git init命令创建本地仓库时默认会创建一个master分支,其他分支可以围绕主分支进行开发

在这里插入图片描述

常用命令

命令 功能
git branch 列出本地的所有分支的简略信息
git branchr 列出所有的远程分支
git brancha 列出所有的本地分支和远程分支
git branch [branchname] 创建分支,分支的内容基于当前分支复制的,包括文件版本信息
git checkout [branchname] 切换分支要求分支必须存在
当前分支上的内容必须先提交到本地库才能切换到其他分支
git checkout [-b] [branchname] 切换分支,如果分支不存在直接创建
git push [short-Name] [branchname] 推送资源远程仓库的某个分支
git merge [branchname] 合并某个分支的资源到当前分支
git branchd [branchname] 删除某个分支,会做检查对于还没有合并的分支可能无法删除
删除分支时不能删除当前分支,只能删除其他分支
git branch -D [branch-name] 强制删除分支
git push [short-Name] –d [branch-name] 删除远程仓库中的某个分支

git branch -v(可省略): –v表示查看本地所有分支的详细信息,*代表当前所在的分支

#查看本地所有分支的详细信息
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch -v
#当前分支是mater分支的my first版本
* master 087a1a7 my first commit 

#查看本地所有分支的简略信息
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch
* master 

git branch 分支名: 创建分支, 分支的内容基于当前分支复制的(包括指向的文件版本),创建后如果再修改主分支的内容也不会影响子分支

git branch -d/-D 分支名: 删除分支,-d表示删除需要做各种检查,当删除没有合并的分支时会出现删除不了的情况,-D表示强制删除不做检查

#在当前分支的基础上创建hot-fix分支
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch hot-fix
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch -v
hot-fix 087a1a7 my first commit 
* master 087a1a7 my first commit

git checkout 分支名: 切换分支,当前分支上的内容必须先提交到本地库才能切换到其他分支

git checkout -b 分支名: 切换分支,如果分支不存在则直接创建,创建的分支的内容是基于当前分支复制的

Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git checkout hot-fix
Switched to branch 'hot-fix'
#发现当先分支已由master改为hot-fix
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)

#查看hot-fix分支上的文件内容发现与master分支上的内容相同
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ cat hello.txt
hello git! hello atguigu!
#在hot-fix分支上同样需要进行文件的修改-->提交文件到暂存区-->提交到本地库-->查看版本的信息(不会影响到主分支的内容)

master,hot-fix其实都是指向具体版本记录指针,当前所在的分支其实是由HEAD决定的,所以创建分支的本质就是多创建一个指针

  • HEAD如果指向master: 那么我们现在就在master分支上 , master分支指向具体的版本
  • HEAD如果指向hotfix: 那么我们现在就在hotfix分支上, hotfix分支也指向具体的版本

在这里插入图片描述

每个分支都是独立副本(都有各自的文件),修改创建的分支内容是不会影响主分支的内容

#在hot-fix分支上做修改
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ vim hello.txt
hello git! hello atguigu! hot-fix test
#添加暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ git add hello.txt
#提交本地库
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ git commit -m "hot-fix commit" hello.txt

#切换mster分支
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ git checkout master

#master分支上还是第一次提交的版本内容
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ cat hello.txt
hello git! hello atguigu!

git merge 分支名: 将指定分支合并到当前分支,如在master分支执行合并命令,表示将其他分支上的资源合并到主分支,合并分支时会有提示输入wq可退出

在这里插入图片描述

#在maste分支上做修改
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ vim hello.txt
hello git! hello atguigu! master test
#添加暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git add hello.txt
#提交本地库
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git commit -m "master test" hello.txt
[master f363b4c] master test commit
1 file changed, 1 insertion(+), 1 deletion(-)

#再次修改在hot-fix分支上做修改
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ vim hello.txt
hello git! hello atguigu! hot-fix test
hello git! hello atguigu! hot-fix test
#添加暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git add hello.txt
#提交本地库
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git commit -m "hot-fix test test" hello.txt
[master f363b4c] hot-fix test test commit
1 file changed, 1 insertion(+), 1 deletion(-)

#在master分支上合并hot-fix分支
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git merge hot-fix
Auto-merging hello.txt
CONFLICT (content): Merge conflict in hello.txt#合并时hello.txt文件有冲突
Automatic merge failed; fix conflicts and then commit the result
#冲突产生的表现:后面状态为 MERGING
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
#查看状态检测到有文件有两处修改)
$ git status
On branch master
You have unmerged paths.
 (fix conflicts and run "git commit")
 (use "git merge --abort" to abort the merge)
Unmerged paths:
 (use "git add <file>..." to mark resolution)
 both modified: hello.txt
no changes added to commit (use "git add" and/or "git commit -a")

冲突合并

冲突合并: 合并分支时,如果有两个/多个分支对同一个文件的同一个位置有两套完全不同的修改时,Git不知道使用哪一个分支修改的值, 此时就发生了冲突

#编写冲突的文件
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
$ vim hello.txt
<<<<<<< HEAD
当前分支的冲突代码 
=======
合并过来分支的冲突代码 
>>>>>>> hot-fix

#添加到暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
$ git add hello.txt
#提交本地库(此时使用git commit命令时不能带文件名
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
$ git commit -m "merge hot-fix"
[master 69ff88d] merge hot-fix
#发现后面MERGING消失,变为正常
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)

原文地址:https://blog.csdn.net/qq_57005976/article/details/134738466

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_24222.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注