有次推送了Git的基本配置。原文在这里
Git作为团队开发的利器,在面试的时候,被问到的概率很大。
基础部分--大家平时都用什么工具?出了Git自带的命令行工具外,作为iOS开发,接触最多的当然就是Xcode自带的Source Control功能。但是这两个工具都有一些自己的不足。
Xcode本身自己是支持Git的,但是有个不足之处,就是卡顿。文件越大越卡,甚至会Crash。所以对于.pbxproj这种大文件的冲突,Xcode基本是蒙圈状态的。另外它就是提供Git支持也有些单薄。
命令行
SourceTree
SmartGit
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可以将一个分支的末端指向前一个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不支持文件层面的操作。