在一个分支上开发了很长一段时间后,我切换到了master。日志显示:
你的分支比“origin/master”慢了167次提交,并且可以快进。
我试着:
git checkout HEAD
它没有任何效果。这是因为我在master上签出了一个中间提交。
我怎样才能使主人保持头脑清醒?
在一个分支上开发了很长一段时间后,我切换到了master。日志显示:
你的分支比“origin/master”慢了167次提交,并且可以快进。
我试着:
git checkout HEAD
它没有任何效果。这是因为我在master上签出了一个中间提交。
我怎样才能使主人保持头脑清醒?
当前回答
在我的方式,它返回所有改变的头,是最快的方式:
git fetch origin master
git reset --hard FETCH_HEAD
git clean -df
其他回答
git checkout master
git pull
应该做这份工作。
每次当你在不同于master的分支上工作时,你都会得到“你的分支落后”消息,有人对master进行了更改,而你git拉。
(branch) $ //hack hack hack, while someone push the changes to origin/master
(branch) $ git pull
现在,源/主引用被拉出,但您的主引用没有与其合并
(branch) $ git checkout master
(master) $
现在master在origin/master后面,可以快速前进了
this will pull and merge (so merge also newer commits to origin/master)
(master) $ git pull
this will just merge what you have already pulled
(master) $ git merge origin/master
现在你的master和原点/master是同步的
尝试git合并origin/master。如果你想确保它只做快进,你可以说git merge——ff-only origin/master。
在我的方式,它返回所有改变的头,是最快的方式:
git fetch origin master
git reset --hard FETCH_HEAD
git clean -df
做的事情:
git checkout master
git pull origin
将获取并合并origin/master分支(你可能会说git pull as origin是默认的)。
要将当前本地跟踪器分支移动到最新的远程状态之上,需要重新设置本地跟踪器分支:
git fetch && git rebase
一般来说,快进和删除本地更改(硬重置)*:
git fetch && git checkout ${the_branch_name} && git reset --hard origin/${the_branch_name}
快进并保持本地更改(rebase):
git fetch && git checkout ${the_branch_name} && git rebase origin/${the_branch_name}
* -要撤消无意硬重置造成的更改,首先做git reflog。它以相反的顺序显示HEAD的状态。找到HEAD在重置操作之前指向的散列(通常是明显的),并将分支硬重置到该散列。