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 条评论
登录 后参与评论

相关文章

来自专栏运维一切

mfs挂载失去连接问题 原

我在系统上部署了一个web应用,这个应用使用了mfs挂载使用静态资源,但是每次就突然进程没了,挂载点重新挂载又可以了。经查发现居然是因为我分派的内存太小,fpm...

8720
来自专栏假装我会写代码

Laravel Bash 别名

13320
来自专栏影子

给Ionic写一个cordova(PhoneGap)插件

13240
来自专栏小李刀刀的专栏

[译]Laravel 5.0 之目录结构与命名空间

本文译自 Matt Stauffer 的系列文章. ---- Laravel 的主版本号之所以从 4 升到 5. 一个很重要的原因是目录结构的改变. 这个改变实...

36540
来自专栏竹清助手

Laravel 5 系列入门教程(一)【最适合中国人的 Laravel 教程】

2. http://www.golaravel.com/laravel/docs/5.0/

73120
来自专栏iOSDevLog

使用 pod lib create 创建库

我们将使用pod lib create引导过程来创建整个pod 。那么让我们从初始命令开始:

31810
来自专栏FreeBuf

打开文件夹就运行?COM劫持利用新姿势

*本文原创作者:菠菜,本文属FreeBuf原创奖励计划,未经许可禁止转载 打开文件夹就能运行指定的程序?这不是天方夜谭,而是在现实世界中确实存在的。利用本文探讨...

27880
来自专栏中国白客联盟

Http Options出血漏洞CVE-2017-9798 可导致内存泄漏 PoC已公开

周一,研究员Hanno Böck发现HTTP Options存在出血漏洞CVE-2017-9798,如果网站管理员尝试对无效的 HTTP 方法实施 "Limi...

39850
来自专栏影子

给Ionic写一个cordova(PhoneGap)插件

501100
来自专栏腾讯移动品质中心TMQ的专栏

QQ浏览器性能提升之路——windows性能分析工具篇

对普通用户而言,评判一款浏览器是否优秀,最直观的体验就是速度,但随着新功能的迭代,不断的开始有用户反馈浏览器开始变慢,这时候就需要进行性能优化了。而在Windo...

50650

扫码关注云+社区

领取腾讯云代金券