泪流满面的 11 个 Git 面试题

在今年的 Stack Overflow 开发者调查报告中,超过 70% 的开发者使用 Git,使其成为世界上使用人数最多的版本控制系统。Git 通常用于开源和商业软件开发,对个人、团队和企业都颇有益处。

Q1: 什么是 Git 复刻(fork)?复刻(fork)、分支(branch)和克隆(clone)之间有什么区别?

主题:Git 难度:⭐⭐

  • 复刻(fork) 是对存储仓库(repository)进行的远程的、服务器端的拷贝,从源头上就有所区别。复刻实际上不是 Git 的范畴。它更像是个政治/社会概念。
  • 克隆(clone) 不是复刻,克隆是个对某个远程仓库的本地拷贝。克隆时,实际上是拷贝整个源存储仓库,包括所有历史记录和分支。
  • 分支(branch) 是一种机制,用于处理单一存储仓库中的变更,并最终目的是用于与其他部分代码合并。

🔗来源: stackoverflow.com

 

Q2: “拉取请求(pull request)”和“分支(branch)”之间有什么区别?

主题:Git 难度:⭐⭐

  • 分支(branch) 是代码的一个独立版本。
  • 拉取请求(pull request) 是当有人用仓库,建立了自己的分支,做了些修改并合并到该分支(把自己修改应用到别人的代码仓库)。

🔗来源: stackoverflow.com

 

Q3: “git pull”和“git fetch”之间有什么区别?

主题:Git 难度:⭐⭐

简单来说,git pullgit fetch + git merge

  • 当你使用 pull,Git 会试着自动为你完成工作。它是上下文(工作环境)敏感的,所以 Git 会把所有拉取的提交合并到你当前处理的分支中。pull 则是 自动合并提交而没有让你复查的过程。如果你没有细心管理你的分支,你可能会频繁遇到冲突。
  • 当你 fetch,Git 会收集目标分支中的所有不存在的提交,并将这些提交存储到本地仓库中。但Git 不会把这些提交合并到当前分支中。这种处理逻辑在当你需要保持仓库更新,在更新文件时又希望处理可能中断的事情时,这将非常实用。而将提交合并到主分支中,则该使用 merge

🔗来源: stackoverflow.com

 

Q4: 如在 Git 恢复先前的提交?

主题:Git 难度:⭐⭐⭐

假设你的情形是这样,其中 C 是你的 HEAD,(F) 是你文件的状态。

You may also like...