文章目录
-
- 问题1、什么是 fork?fork、branch和clone之间有什么区别?
- 问题2、“pull request”和“branch”之间有什么区别?
- 问题3、“git pull”和“git fetch”之间有什么区别?
- 问题4、如在 Git 恢复先前的提交?
- 问题5、什么是“git cherry-pick”?
- 问题6、Forking 工作流程的优点
- 问题7、Git 中 HEAD、工作树和索引之间的区别?
- 问题8、Gitflow 工作流程?
- 问题9、什么时候应使用 “git stash”?
- 问题10、如何从 git 中删除文件,而不将其从文件系统中删除?
- 问题10、么时候使用“git rebase”代替“git merge”?
问题1、什么是 fork?fork、branch和clone之间有什么区别?
- 复刻(fork) 是对存储仓库(repository)进行的远程的、服务器端的拷贝,从源头上就有所区别。复刻实际上不是 Git 的范畴。它更像是个政治/社会概念。
- 克隆(clone) 不是复刻,克隆是个对某个远程仓库的本地拷贝。克隆时,实际上是拷贝整个源存储仓库,包括所有历史记录和分支。
- 分支(branch) 是一种机制,用于处理单一存储仓库中的变更,并最终目的是用于与其他部分代码合并。
问题2、“pull request”和“branch”之间有什么区别?
- 分支(branch) 是代码的一个独立版本。
- 拉取请求(pull request) 是当有人用仓库,建立了自己的分支,做了些修改并合并到该分支(把自己修改应用到别人的代码仓库)。
问题3、“git pull”和“git fetch”之间有什么区别?
简单来说,git pull 是 git fetch + git merge。
- 当你使用 pull,Git 会试着自动为你完成工作。它是上下文(工作环境)敏感的,所以 Git 会把所有拉取的提交合并到你当前处理的分支中。pull 则是 自动合并提交而没有让你复查的过程。如果你没有细心管理你的分支,你可能会频繁遇到冲突。
- 当你 fetch,Git 会收集目标分支中的所有不存在的提交,并将这些提交存储到本地仓库中。但Git 不会把这些提交合并到当前分支中。这种处理逻辑在当你需要保持仓库更新,在更新文件时又希望处理可能中断的事情时,这将非常实用。而将提交合并到主分支中,则该使用 merge。
参考:https://stackoverflow.com/questions/292357/what