[每周一更]-(第69期):特殊及面试的GIT问题解析

整合代码使用过程的问题,以及面试遇到的细节,汇总一些常用命令的对比解释和对比;

1、fetch和pull区别

git fetch是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。

git pull则是将远程主机的最新内容拉下来后直接合并,即:git pull = git fetch + git merge,这样可能会产生冲突,需要手动解决。

2、可以作为一套面试及、如何处理一个或一系列相连的分支feature提交的commits 合并到master分支;

(1)合并非master中某个commit提交到master分支中,用git cherry-pick命令,

git checkout master

git cherry-pick 22ecb3(提交记录 git log 查看)

也可以合并一系列:

git cherry-pick A...B (提交 A 必须早于提交 B)

git cherry-pick A^...B (包含A当前分支)

(2)当需要合并一系列commit时,就需要用到rebase

首先需要基于feature创建一个新的分支,并指明新分支的最后一个commit:

git checkout -b newbranch 22ecb3

然后,rebase这个新分支的commit到master(--ontomaster)。76cada^ 指明你想从哪个特定的commit开始。

git rebase --onto master 11cada^

得到的结果就是feature分支的commit 22ecb3 ~ 11cada 都被合并到了master分支。

回退上个版本:git reset --hard HEAD^

3、当master分支合并了其他分支内容,想去除?(很棒的方式)

(1) 先查看提交记录, git log --pretty=oneline

(2)用【git reset】回到出错版本的上一个版本 :git reset --hard 3c2af5a7(表示错误前的一个版本)

(3)用【git cherry-pick】把出错版本后面的commit合并进去;git cherry-pick 9dba07f4^...32aba548

#出错版本后的第一个commit直至最新commit或者使用单次合并 git cherry-pick 9dba07f4

#将某次commit的更改应用到当前版本(将出错 cmmit 之后别人提交的代码合并到当前正常代码分支上)

栗子:git cherry-pick 396c2fd9^...aafc97e3

(4)如果在cherry-pick 的过程中出现了冲突 ,在处理冲突后,使用 git cherry-pick --continue

(5)继续处理下一个分支 如果想中途退出cherry-pick,使用 git cherry-pick --abort

(6)合并冲突后,使用强制推送把旧分支进行覆盖 :git push origin HEAD:commitName(当前版本名) --force

git push origin HEAD --force #强制提交

查看更多

相关推荐
l and2 小时前
Git 行尾换行符,导致无法进入游戏
android·git
风行男孩2 小时前
Git 中忽略文件的版本跟踪(初级方法及高级方法)
git
ziyu_jia2 小时前
【日常开发】Git Stash使用技巧
git·git stash
catmes9 小时前
Git开发常用命令总结
git
是姜姜啊!14 小时前
git命令
git
云只上18 小时前
git更改当前项目的远程仓库,保留原始仓库提交记录提交到新仓库
git
__zhangheng19 小时前
Mac 查询IP配置,网络代理
linux·服务器·网络·git
乐闻x19 小时前
VSCode 插件开发实战(十二):如何集成Git操作能力
ide·git·vscode
旺旺大力包1 天前
【 Git 】git 的安装和使用
前端·笔记·git
Domain-zhuo1 天前
Git和SVN有什么区别?
前端·javascript·vue.js·git·svn·webpack·node.js