V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
coolair
V2EX  ›  问与答

git 修改了多个文件提交的时候你们是每个文件 add 写 commit 还是只写一次啊?

  •  
  •   coolair · 2016-10-28 10:05:50 +08:00 · 6424 次点击
    这是一个创建于 2956 天前的主题,其中的信息可能已经有所发展或是发生改变。
    比如:在编辑文件 B 的时候,发现文件 A 有些地方写的不妥,然后就把 A 给改了,改 A 的时候发现文件 C 又有点问题,又顺手把 C 给改了。
    改的三处都是不同功能的修改,当 A 、 B 、 C 都完工,要 push 代码的时候,是一个一个 add 写完 commit ,然后 push ,还是就 add ., commit 就针对 B 的写,然后 push ?
    如果是后者,就会不妥吧,看 commit 的时候发现新增 B 这个功能怎么扯到 A 和 C 了?
    17 条回复    2016-10-28 15:49:17 +08:00
    tracyone
        1
    tracyone  
       2016-10-28 10:14:09 +08:00 via iPhone
    看心情
    GhostFlying
        2
    GhostFlying  
       2016-10-28 10:15:08 +08:00 via Android
    一个一个,你也说不妥了
    Vindroid
        3
    Vindroid  
       2016-10-28 10:21:46 +08:00
    按功能划分提交吧
    malkavia
        4
    malkavia  
       2016-10-28 10:36:22 +08:00
    一个一个,方便 codereview ,方便回 revert
    psklf
        5
    psklf  
       2016-10-28 10:42:00 +08:00
    >add ., commit 就针对 B 的写,然后 push ?

    应该是你 commit 把所有的信息都写上
    cha0s
        6
    cha0s  
       2016-10-28 10:43:49 +08:00 via iPad
    一次提交,写清楚就行了。需要单独 review 时候 cherry 就行
    Jiki
        7
    Jiki  
       2016-10-28 12:18:32 +08:00 via iPhone
    一个个写回退方便点,清晰点……一起写就写具体点,加上 commit 详情也挺清楚的。
    还有就是改动引发次生问题和修改的可能,以及心情▼_▼
    kevinzhwl
        8
    kevinzhwl  
       2016-10-28 13:31:01 +08:00 via iPhone
    看心情,另外改 b 的时候别瞎看 ac ,容易爱心泛滥。哈哈
    Layne
        9
    Layne  
       2016-10-28 13:51:10 +08:00
    按功能来
    happypy1
        10
    happypy1  
       2016-10-28 15:19:20 +08:00
    原则上是不同目的的修改是放在不同的 commit 里的。

    如果你的 a , b , c 的改动都是互不关联的话,不嫌麻烦,就分开放。

    不过通过很多次实践证明,你省了一时的麻烦,将来就有更多呃麻烦来找你。自己掂量吧。
    tobeyouth
        11
    tobeyouth  
       2016-10-28 15:21:47 +08:00
    如果这几个文件的修改是强关联的,还是一起提交比较好
    otakustay
        12
    otakustay  
       2016-10-28 15:30:48 +08:00   ❤️ 1
    保证每个 commit 是能过 ci 和可运行的
    pagict
        13
    pagict  
       2016-10-28 15:32:49 +08:00
    多用 branch
    nailuoGG
        14
    nailuoGG  
       2016-10-28 15:34:59 +08:00
    可以按功能来新建分支,就不会忘记自己改了哪些东西了。
    ycge234
        15
    ycge234  
       2016-10-28 15:44:11 +08:00   ❤️ 1
    '每个提交都应该保持原子性'
    csdreamdong
        16
    csdreamdong  
       2016-10-28 15:46:13 +08:00
    git amend
    9hills
        17
    9hills  
       2016-10-28 15:49:17 +08:00
    改 A 的时候发现 B 有其他问题,解决办法就是开个新的 branch ,只改 B 。当前的 branch ,只改 A
    之后再 merge 到一起
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2610 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 03:40 · PVG 11:40 · LAX 19:40 · JFK 22:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.