GitHub如何手动同步上游更改

手动同步更改

GitHub Classroom 的同步更改功能 bug 较多。如果你遇到了无法同步最新更改的问题,可以尝试下面的方法解决:

第零步:暂存或提交当前更改

在开始之前请务必先使用 git stash 暂存当前未提交的更改,或者使用 git commit 直接提交,避免出现问题 如果暂存,在完成之后你可以使用 git stash pop 恢复

第一步:添加远程仓库

如果你已经添加过仓库,请跳过这一步直接进入第二步;否则在本地仓库运行下面的命令:

arduino 复制代码
git remote add template https://github.com/RUCICS/ShellLab-2025.git

这条命令将上游仓库(即原始作业仓库)添加为一个新的远程仓库,并将其命名为"template"。这样我们就建立了与上游仓库的连接,方便后续获取最新更改。

第二步:获取上游仓库的更新

arduino 复制代码
git fetch template main

该命令从上游仓库的main分支获取最新的代码更新。需要注意的是,这一步只是将更新下载到本地,但还没有将这些更改应用到你的代码中。

第三步:将更新整合到本地代码

arduino 复制代码
git merge template/main

这条命令会将你的本地修改建立在上游仓库最新代码的基础之上。它会先暂存你的本地修改,然后应用上游的更新,最后将你的修改重新应用到更新后的代码上。如果过程中发生冲突,你需要手动解决这些冲突。

如何解决冲突

当执行 git merge template/main 时遇到冲突,Git 会暂停 merge 过程并提示你解决冲突。

以下是解决冲突的具体步骤:

  1. 当发生冲突时,Git 会在终端显示类似这样的提示:
xml 复制代码
CONFLICT (content): Merge conflict in <文件名>
Auto-merging <文件名>
  1. 打开发生冲突的文件,你会看到类似这样的标记:
markdown 复制代码
<<<<<<< HEAD
你的代码
=======
上游仓库的代码
>>>>>>> template/main
  1. 解决冲突:
  • <<<<<<< HEAD======= 之间的内容是你的修改
  • =======>>>>>>> template/main 之间的内容是上游仓库的代码
  • 你需要决定保留哪些代码,删除哪些代码,或者如何合并它们
  • 删除所有的冲突标记(<<<<<<<=======>>>>>>>
  1. 解决完冲突后,使用以下命令将文件标记为已解决:
csharp 复制代码
git add <发生冲突的文件名>
  1. 继续 merge 过程:
kotlin 复制代码
git merge --continue

如果还有其他文件的冲突,重复步骤 3-5,直到所有冲突都解决完毕。

如果在解决冲突过程中遇到问题,随时可以使用以下命令取消 merge:

sql 复制代码
git merge --abort

这会将代码恢复到执行 merge 之前的状态,你可以重新开始。

提示:解决冲突时,建议先仔细阅读冲突的代码,理解两边的修改意图,再决定如何处理。

相关推荐
IceSugarJJ27 分钟前
Open-AutoGLM项目学习
语言模型·微信小程序·github
阿里嘎多学长1 小时前
2026-05-22 GitHub 热点项目精选
开发语言·程序员·github·代码托管
Dontla2 小时前
Github创建项目(创建仓库、新建项目、新建仓库)步骤
github
放下华子我只抽RuiKe52 小时前
React 从入门到生产(七):性能优化实战
前端·javascript·人工智能·react.js·性能优化·前端框架·github
晓杰'2 小时前
Balatro后端进阶(2):基于GitHub Actions的CI自动化验证实现
websocket·ci/cd·typescript·node.js·自动化·github·nestjs
析数塔3 小时前
Codegraph 实战:用知识图谱让 AI 编程效率翻倍
人工智能·github
葬送的代码人生4 小时前
别再「Ctrl+C/V」了!Git 开发必备技能,10 分钟告别单机码农
前端·github·代码规范
码农翻身4 小时前
GitHub,2008年生,2048年卒
github
文滨4 小时前
10分钟搞定!Mac 配置 GitHub SSH 完全指南(小白也能看懂)
前端·macos·ssh·github
MicrosoftReactor4 小时前
技术速递|六个编码智能体,一个生产级系统:基于 AKS-Lab-GitHubCopilot 的 AgenticOps 实战指南
ai·github·copilot·智能体