《Git快速入门》Git分支

1.master、origin、origin/master 区别

首先搞懂git分支的一些名称区别:

master : Git 的默认分支名字。它并不是一个特殊分支、跟其它分支完全没有区别。 之所以几乎每一个仓库都有 master 分支,是因为 git init 命令默认创建它,并且大多数人都懒得去改动它。

origin :Git 克隆的仓库服务器的默认名字。

origin/master:是当本地的 master 分支同步到服务时的名字。如果分支名称为 ForDebug、当分支同步到服务器时、会看到服务器上的名字为 origin/ForDebug。

注:master是一个默认分支名称,origin是一个默认仓库服务器名,服务器名和分支名是两个概念

2.查看分支的指令

#查看本地仓库分支

git branch

#查看远程仓库分支

git branch -r

#查看全部(远程和本地)仓库分支

git branch -a

3.创建本地分支

复制代码
// 写法一:创建新分支
git checkout -b yourbranch    // yourbranch 新分支名
 
// 写法二:基于某分支创建自己的新分支
git checkout -b yourbranch origin/basebranch   // basebranch老分支名
 
// 写法三:
git branch yourbranch      //创建某个分支
git checkout yourbranch    //表示切换到某个分支

4.删除分支

4.1 删除本地分支
复制代码
# 如果分支包含未合并的更改和未推送的提交,则 -d 标志将不允许删除本地分支
# -d 是 --delete 的别名
git branch -d [branch_name] 
 
# 强制删除本地分支,不考虑其合并状态
# -D 是 --delete --force 的别名
git branch -D [branch_name] 
4.2 删除远程分支
复制代码
git push <远程仓库名称> -d [分支名称]

注:此处的分支名称不要带远程仓库名称,示例:

复制代码
git push origin -d LIO-SAM_jq

5.提交本地代码到远程仓库分支

复制代码
git push <远程仓库名称> <本地仓库分支>:<远程仓库分支>

注意:遵循"从哪到哪的原则",同样此处远程仓库分支不要带仓库名称,示例:

复制代码
git push origin master:LIO-SAM_jq

6.本地分支的使用方法

在一个项目中,默认的分支为master,下面展示如何在一个新的分支上修改代码,而不改变主分支的代码。

6.1 创建新的分支A

复制代码
git checkout -b A

6.2 在新的分支A上新创将一个A.cpp文件

复制代码
vim A.cpp

6.3 提交改动到缓存区

复制代码
git add .

6.4 提交改动到本地仓库分支

复制代码
git commit -m "备注"

经过上面4个步骤,我们在新的分支上修改了代码,并提交到了本地仓库分支,当我们切换回master分支后,会发现本地的A.cpp文件不存在。

注意 :缓存区是本地所有的分支共享的,因此只进行到了6.3步骤的话,切换回master主分支后,会发现A.cpp文件依旧存在。

相关推荐
痕忆丶3 分钟前
git 软重置的使用场景git reset --soft HEAD~1
git
sijiaoh5 分钟前
用Renovate处理Private Submodules
ci/cd·github
向葭奔赴♡26 分钟前
Android AlertDialog实战:5种常用对话框实现
android·java·开发语言·贪心算法·gitee
小年糕是糕手27 分钟前
【C++】类和对象(六) -- 友元、内部类、匿名对象、对象拷贝时的编译器优化
开发语言·c++·算法·pdf·github·排序算法
杰瑞学AI1 小时前
在Git的缩写哈希中踩的坑
git
dragoooon342 小时前
[Linux网络基础——Lesson9.「TCP 全连接队列与 tcpdump 抓包」]
前端·git·github
多想和从前一样2 小时前
GitHub Desktop提交文件报错:连接问题
github
wan_da_ren3 小时前
Windows 环境下使用 Go Modules 拉取带外层 Basic Auth 的私有 GitLab 仓库 — 完整解决方案
windows·golang·gitlab
大、男人3 小时前
分享一个git设备代理的方法
git
CPU NULL3 小时前
Claude Code/Codex在WSL下粘贴图片的工具
github·开源软件