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
相关推荐
snoopyfly~4 小时前
Ubuntu 24.04 LTS 服务器配置:安装 JDK、Nginx、Redis。
java·服务器·ubuntu
Me4神秘5 小时前
Linux国产与国外进度对垒
linux·服务器·安全
&Sinnt&6 小时前
Git 版本控制完全指南:从入门到精通
git·后端
Me4神秘6 小时前
电信、移动、联通、广电跨运营商网速慢原因
网络
数通Dinner7 小时前
RSTP 拓扑收敛机制
网络·网络协议·tcp/ip·算法·信息与通信
牛奶咖啡138 小时前
Linux系统的常用操作命令——文件远程传输、文件编辑、软件安装的四种方式
运维·服务器·软件安装·linux云计算·scp文件远程传输·vi文件编辑·设置yum的阿里云源
weixin_437398218 小时前
转Go学习笔记(2)进阶
服务器·笔记·后端·学习·架构·golang
Tiny2148 小时前
多人协同开发时Git使用命令
git
liulilittle8 小时前
SNIProxy 轻量级匿名CDN代理架构与实现
开发语言·网络·c++·网关·架构·cdn·通信
tan77º9 小时前
【Linux网络编程】Socket - UDP
linux·服务器·网络·c++·udp