您的位置:首页 > 职场人生

Git面试常见问题

2021-02-28 21:49 1011 查看

有次推送了Git的基本配置。原文在这里


Git作为团队开发的利器,在面试的时候,被问到的概率很大。

基础部分--大家平时都用什么工具?

  • 出了Git自带的命令行工具外,作为iOS开发,接触最多的当然就是Xcode自带的Source Control功能。但是这两个工具都有一些自己的不足。

  • Xcode本身自己是支持Git的,但是有个不足之处,就是卡顿。文件越大越卡,甚至会Crash。所以对于.pbxproj这种大文件的冲突,Xcode基本是蒙圈状态的。另外它就是提供Git支持也有些单薄。

  • 命令行

  • SourceTree

  • SmartGit


git add 和git stage有什么区别

  • Git仓库的三个组成部分:工作区(Working Directory)、暂存区(Stage)、历史记录区(History)

  • 工作区:在Git管理的正常目录都算是工作区,我们平时编辑工作都是在工作区完成。

  • 暂存区:临时区域。里面存放将要提交的文件快照。

  • 历史记录区:git commit 后的记录区。

  • git add 和git stage,其实这两个命令是同一个意思,是因为要跟 svn add 区分,两者的功能是完全不一样的,svn add 是将某个文件加入版本控制,而 git add 则是把某个文件加入暂存区,因为在 git 出来之前大家用 svn 比较多,所以为了避免误导,git 引入了git stage,然后把 git diff --staged 做为 git diff --cached 的相同命令。基于这个原因,我们建议使用 git stage 以及 git diff --staged。

git reset 、git revert和git checkout 有什么区别?

  • 共同点:用来撤销代码仓库中的某些更改。

  • 不同点

    git reset可以将一个分支的末端指向前一个commit。然后再下次git执行垃圾回收的时候,会把这个commit之后的commit都扔掉。

  • git reset还支持三种标记。用来标记reset指令的影响范围。

  • --mixed:会影响到暂存区和历史记录区。也是默认选项。

  • --soft:只影响历史记录区。

  • --hard:影响工作区,暂存区和历史记录区。

注意,因为git reset是直接删除commit记录,从而会影响其他开发人员的分支,所以不要在公共分支做这个操作。

  • git checkout 可以将HEAD移到一个新的分支,并更新工作目录。以为可能会覆盖本地的修改,所以执行这个指令之前,你需要stash或者commit暂存区和工作区的更改。

  • git revert和git reset的目的是一样的,但是做法不一样,它会创建新的commit的方式来撤销commit,这样能保留之前的 commit 历史,比较安全。另外,同样因为可能会覆盖本地的修改,所以执行这个指令之前,你需要 stash 或者 commit 暂存区和工作区的更改。


然后从文件的层面来说:

  • git reset 只是把文件从历史记录区拿到暂存区,不影响工作区的内容,而且不支持 --mixed、--soft 和 --hard。

  • git checkout 则是把文件从历史记录拿到工作区,不影响暂存区的内容。

  • git revert不支持文件层面的操作。


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: