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

相关文章

来自专栏程序你好

一个微服务架构的简单示例

2403
来自专栏黑白安全

iOS安全基础之钥匙串与哈希

本文最初是由Chris Lowe编写的,后来经过Ryan Ackermann(ios系统开发者)的修改,已经可以针对最新的Xcode 9.2,Swift 4,i...

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

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

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

3845
来自专栏影子

给Ionic写一个cordova(PhoneGap)插件

45510
来自专栏编程坑太多

『中级篇』镜像的发布(18)

####具体的dockerhub如何注册,我就不解释了。今天的任务就是把自己的image push到自己的docker push里面,请看我的表演!

1777
来自专栏LinXunFeng的专栏

解决Cocoapods贼慢问题

3865
来自专栏竹清助手

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

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

2862
来自专栏中国白客联盟

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

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

3695
来自专栏编程坑太多

『中级篇』镜像的发布(18)

1236
来自专栏张善友的专栏

一款免费的.NET智能持续测试运行工具——Mighty-Moose

Mighty-Moose是一款面向.NET的持续构建和测试运行工具,现在它免费发放了。 那么Mightly-Moose到底是干什么的呢?当你每次在Visual ...

20210

扫码关注云+社区