git远程仓库分支推送与常见问题

1.查看远程仓库分支情况

bash 复制代码
git fetch origin
git branch -r

2.删除远程仓库中的某一分支(如master)

bash 复制代码
git push origin --delete master


问: 如果我的本地文件只有一个分支main,而远程仓库有两个分支Main和CubeMX, 若要将本地文件中新增的文件Test1.txt更改放入CubeMX中,是不是必须先拉取远程分支CubeMX到本地,然后才能推送到远程CubeMX?

是的,为了将本地 main 分支中新添加的 Test1 文件的更改合并到远程仓库的 CubeMX 分支,

你需要按照以下步骤操作:

1.拉取远程仓库的 CubeMX 分支

首先确保本地拥有远程仓库的 CubeMX 分支的最新版本。

bash 复制代码
git fetch origin CubeMX

如果你从未在本地创建过 CubeMX 分支,可以创建并切换到该分支,并与远程 CubeMX 分支关联:

2. 将本地CubeMX(前者)与远程CubeMX(后者)分支关联

bash 复制代码
git checkout -b CubeMX origin/CubeMX

将 main 分支的更改合并到 CubeMX 分支: 切换回 main 分支,确保 Test1 文件已经添加到暂存区并提交:

bash 复制代码
git checkout main
git add Test1.txt
git commit -m "Add Test1.txt to main"

3.将 main 分支的更改合并到 CubeMX 分支:

bash 复制代码
git checkout CubeMX
git merge main

推送到远程 CubeMX 分支

确认无误后,将 CubeMX 分支的更改推送到远程仓库:

bash 复制代码
git push origin CubeMX

这样,Test1.txt文件的更改就成功地被合并到了远程仓库的 CubeMX 分支上。


问:本地可以不创建分支,直接将本地main与远程CubeMX分支关联后,再将修改提交到CubeMX中吗?使用完后再取消关联,这样本地就不需要额外再创建main以外的分支了?

理论上是可以的,但实际操作并不建议这样做,因为这样可能会混淆本地分支和远程分支的职责。不过,如果你确实希望暂时将本地 main 分支的更改推送到远程 CubeMX 分支,并在操作完成后解除关联,可以采用以下方式:

将本地 main 分支与远程 CubeMX 分支关联: 首先,你需要在本地创建一个与远程 CubeMX 分支关联的新分支,这里我们只是暂时关联,操作完成后可以删除这个分支。

bash 复制代码
git fetch origin
git branch --set-upstream-to=origin/CubeMX main

将本地更改推送到远程 CubeMX 分支: 确保 Test1 文件已经被添加到暂存区并提交到本地 main 分支。

bash 复制代码
git add Test1
git commit -m "将新增Test1文件加入远程CubeMX分支"

然后,将本地 main 分支的更改推送到远程 CubeMX 分支。

bash 复制代码
git push

取消关联: 推送成功后,你可以解除 main 分支与远程 CubeMX 分支的关联。

bash 复制代码
git branch --unset-upstream

虽然这种方法可以避免在本地创建额外的分支,但容易让人误解本地 main 分支的角色,而且不利于长期维护和理解分支结构。最佳实践还是推荐在本地创建一个与远程 CubeMX 分支同名的分支,进行相关的操作,完成后可以根据需要删除这个临时分支。

4.直接在 CubeMX 分支上创建并提交 Test.txt 文件

切换到 CubeMX 分支:
如果本地还没有CubeMX分支,现从远程CubeMX拉取到本地

bash 复制代码
git fetch origin CubeMX

设置本地分支与远程分支的追踪关系: 设置本地 main 分支追踪远程 origin/main 分支:

bash 复制代码
git branch --set-upstream-to=origin/main main

或者当前分支已经是main分支,可以使用:
git branch -u origin/main

确保本地 main 分支包含远程仓库 main 分支的最新更改,直接拉取并合并:

bash 复制代码
git pull origin main

如果本地已经有了CubeMX分支且与远程CubeMX关联,直接切换到分支:

bash 复制代码
git checkout CubeMX

在 CubeMX 分支下创建并添加 Test.txt 文件到暂存区:

bash 复制代码
echo "Some content" > Test.txt
git add Test.txt

提交更改:

bash 复制代码
git commit -m "Add Test.txt to CubeMX"

推送到远程仓库:

bash 复制代码
git push origin CubeMX
相关推荐
孟章豪4 小时前
《SQL拼接 vs 参数化,为什么公司禁止拼接SQL?(附真实案例)》
服务器·数据库·sql
不怕犯错,就怕不做5 小时前
linux 如何查看自己的帐号密码及samba的帐号和密码
linux·运维·服务器
李彦亮老师(本人)6 小时前
Rocky Linux 9.x 新特性详解
linux·运维·服务器·centos·rocky linux
NiKick6 小时前
在Linux系统上使用nmcli命令配置各种网络(有线、无线、vlan、vxlan、路由、网桥等)
linux·服务器·网络
带娃的IT创业者6 小时前
WeClaw_42_Agent工具注册全链路:从BaseTool到意图识别的标准化接入
大数据·网络·人工智能·agent·意图识别·basetool·工具注册
zt1985q7 小时前
本地部署开源元搜索引擎 SearXNG 并实现外部访问
服务器·网络协议·开源
摇滚侠8 小时前
系统工作台待办实时提醒,取代五分钟刷新一次,判断有没有新的待办,利用 WebSocket 实现
网络·websocket·网络协议
猩猩—点灯9 小时前
部署远程利器-RustDesk
运维·服务器·网络
半壶清水9 小时前
[软考网规考点笔记]-局域网之以太网标准
网络·笔记·网络协议·考试
biubiubiu07069 小时前
Linux 中 `source` 和 `systemctl daemon-reload` 的区别与踩坑点
linux·运维·服务器