1
*   84b134d - (HEAD, origin/lab_master, lab_master) comment macro defination which is protent to be a fun
|\
| * 735d88f - add small script to ease ctag related option (13 minutes ago) 
* | 6623a94 - add small script to ease ctag related option (4 minutes ago) 
|/
* 0d0913a - add gitignore to ignore ctags file (57 minutes ago) 

735d88f 是 --amend 提交,但是此时发生了冲突,为什么?

我只有一台电脑,我总是在上面编辑文件,我也只有一个本地仓库,而且这个仓库只在这里使用,我认为不可能发生冲突

但它发生了,为什么?

4

2 回答 2

9

最好只修改尚未推送到服务器的提交。一旦你推送了一个提交,如果你尝试修改它并推送它,它将导致冲突,因为你已经更改了历史记录(如服务器上记录的那样)。

于 2012-09-19T17:27:30.670 回答
0

我没有看到冲突的例子。您所做的是从同一时间点进行相同的更改,然后将它们合并。无论哪种方式,您都可以通过将所有内容压缩为一个来解决此问题

git tag finalstate 84b134d
git stash -u
git reset --hard 0d0913a
git checkout finalstate -- .
git add -A
git commit -C finalstate

如果“注释宏”提交和第二个“添加小脚本”提交有效,您可以

git tag finalstate 84b134d
git stash -u
git reset --hard 6623a94
git checkout finalstate -- .
git add -A
git commit -C finalstate

反而。如果你想要第二个,那么

git tag finalstate 84b134d
git stash -u
git reset --hard 735d88f
git checkout finalstate -- .
git add -A
git commit -C finalstate

在 with 之后删除 helper 标签

git tag -d finalstate

如果您在第二次提交之后推送,然后修改,然后拉取,那么您将与冲突合并。不知道为什么您没有针对冲突解决的合并单独提交。您可能在冲突状态下做了更多工作,修复了冲突,添加了所有更改并提交。在这种情况下,我写的最后一组说明将对您有所帮助。

于 2012-09-19T17:17:01.143 回答