《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文件依旧存在。

相关推荐
CoovallyAIHub42 分钟前
无人机拍叶片→AI找缺陷:CEA-DETR改进RT-DETR做风电叶片表面缺陷检测,mAP50达89.4%
算法·架构·github
CoovallyAIHub1 小时前
混合训练反而更差?VLM Agent在训练前协调跨数据集标注,文档布局检测F-score从0.860提升至0.883
算法·架构·github
OpenTiny社区1 小时前
多端开发头疼?TinyVue 3.30 一招搞定,AI还帮你写代码!
前端·vue.js·github
峰向AI2 小时前
Vercel 官方出品,你的 24 小时 AI 编程助手
人工智能·github
研究点啥好呢3 小时前
Github热门项目推荐 | 开放数据的新时代
大数据·人工智能·机器学习·github·数据
不做超级小白3 小时前
开源项目二开为何推荐使用 `git clone --depth 1`?
git·开源
逛逛GitHub3 小时前
帮你节省 65% 的 token,这个 GitHub 项目让 Claude 模仿原始人。
github
信创DevOps先锋4 小时前
Gitee:本土开发者生态的基石与创新引擎
gitee
信创DevOps先锋5 小时前
Gitee DevOps:构筑国产化数字基座,赋能企业信创转型
运维·gitee·devops
字符串str5 小时前
nikto中文解释和常用的github信息收集语法
github