V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
liyafe1997
V2EX  ›  GitHub

git checkout <branch> -- path 和手动复制粘贴有区别吗?

  •  
  •   liyafe1997 · 10 天前 · 364 次点击

    问题背景: 假如我有分支 B 和 C 都基于 A (算是 upstream ),上游 A 在不断更新的同时,B 和 C 各自经过了很多次 commits ,两边差得很远了(并且时不时也会 merge 一下上游 A ,但是依然差得挺远,毕竟各自有各自的 feature )

    但是此时突然想在 C 分支上某个目录完全使用 B 分支的版本(不能直接 merge ,因为会保留在 C 分支上的更改),这时最佳的操作是什么,能不能直接手动把 B 的文件夹复制粘贴替换过来,然后直接 git add & git commit ,这样会不会导致以后 merge A 的最新更改会有问题(期望的行为是以后 merge A 的时候,对这个目录来说,行为会跟 B 分支上的一样)。

    或者用git checkout <branch> -- path,这个我实测了也问了 ChatGPT ,不会在 git 历史中留下记录,跑完之后也只是帮你把文件弄过来而已,还要自己手动 commit ,那么和手动复制粘贴有区别吗?是不是用 git checkout 才是正确的操作,以后才能正确的 merge 上游 A 。

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1009 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 37ms · UTC 20:20 · PVG 04:20 · LAX 13:20 · JFK 16:20
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.