Git面试常见问题

有次推送了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不支持文件层面的操作。

原文发布于微信公众号 - 数据库SQL(SQLdba)

原文发表时间:2018-01-18

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Hadoop数据仓库

HAWQ技术解析(十七) —— 最佳实践

一、HAWQ参数配置最佳实践 (原文地址:http://hawq.incubator.apache.org/docs/userguide/2.1.0.0-inc...

1787
来自专栏文渊之博

数据库副本的自动种子设定(自增长)

背景 在 SQL Server 2012 和 2014 中,初始化 SQL Server Always On 可用性组中的次要副本的唯一方法是使用备份、复制和还...

26611
来自专栏宏伦工作室

全栈 - 3 序言 带好装备Python和Sublime

1574
来自专栏landv

sourcetree跳过注册的方法

1532
来自专栏源码之家

Office人事档案管理系统破解之程

2845
来自专栏沃趣科技

Oracle集群时间同步

在RAC中集群的时间应该是保持同步的,否则可能导致很多问题,比如:依赖于时间的应用会造成数据的错误,各种日志打印的顺序紊乱,这将会影响问题的诊断,严重的可能会导...

1194
来自专栏Java与Android技术栈

Scala学习笔记(一)mac下安装ScalaIDE选择总结

过年前就定(chui)下了目(niu)标(bi),今年要学习一下Scala和Spark赶一下潮流。谁叫落后就要挨打呢,程序员只能不停的学习。一个语言,学习的第一...

772
来自专栏北京马哥教育

Linux开机启动(bootstrap)

计算机开机是一个神秘的过程。我们只是按了开机键,就看到屏幕上的进度条或者一行行的输出,直到我们到达登录界面。然而,计算机开机又是个异常脆弱的过程,我们满心期望的...

835
来自专栏编程软文

Git神器sourceTreesetup,让你的git效率迅速提升

1512
来自专栏搜云库

在 Linux 上搭建Jekyll静态博客

在CentOS,Ubuntu 按照同样步骤安装,Ruby Gems 往往都无法搭建成,每次都是依赖不对,各种奇葩原因,解决办法就是使用 RVM 安装,解决 Ru...

2668

扫码关注云+社区