Git 闯过这 54 关,点亮你的 Git 技能树

seabornlee · 2015年12月30日 · 最后由 zhanglintc 回复于 2016年07月29日 · 10548 次阅读

开篇

如今,Git 大行其道,颇有一统天下之势。 如果你的技能树上 Git 和 Github 的图标还没有点亮的话,你都不好意思说你是程序员。 别说互联网企业,我接触到的许多传统企业都在从 SVN,Clear Case 等迁移到 Git 上,甚至大厂还会有一个团队去定制适合自己企业的 Git 服务器。

很多人简历上写的「精通 Git 与 Github」,但如果你问他熟悉到什么程度的话,回答通常是「就是会用常用的 addcommitpush 操作」。

但工作中我们会遇到一些更加复杂的场景:

* 忽略某些文件
* 创建,删除分支
* 找到最后修改某行代码的人
* commit 后发现里边包含一个不应该提交的文件
* commit 后发现少提交了一些文件
* 一个文件中的多次有改动,怎么做到只提交其中的一部分?
* 怎样整理提交记录使其更加整洁?
* 快速定位是哪一次提交引入了 bug
* ...

作为一线程序员,我们要如何快速学习 Git 以发挥其最大威力呢?

今天我就要向大家介绍一个工具,准确说应该是「游戏」,名字叫「githug」,它把平常可能遇到的一些场景都实例化,变成一个一个的关卡,一共有 55 个关卡:

#1: init
#2: config
#3: add
#4: commit
#5: clone
#6: clone_to_folder
#7: ignore
#8: include
#9: status
#10: number_of_files_committed
#11: rm
#12: rm_cached
#13: stash
#14: rename
#15: restructure
#16: log
#17: tag
#18: push_tags
#19: commit_amend
#20: commit_in_future
#21: reset
#22: reset_soft
#23: checkout_file
#24: remote
#25: remote_url
#26: pull
#27: remote_add
#28: push
#29: diff
#30: blame
#31: branch
#32: checkout
#33: checkout_tag
#34: checkout_tag_over_branch
#35: branch_at
#36: delete_branch
#37: push_branch
#38: merge
#39: fetch
#40: rebase
#41: repack
#42: cherry-pick
#43: grep
#44: rename_commit
#45: squash
#46: merge_squash
#47: reorder
#48: bisect
#49: stage_lines
#50: find_old_branch
#51: revert
#52: restore
#53: conflict
#54: submodule
#55: contribute

安装

首先我们需要来安装这个游戏,githug 是用 Ruby 编写的,可通过如下命令安装: gem install githug

如果遇到权限问题,请加上sudosudo gem install githug

安装成功后,在 Terminal 里进入你常用的目录,输入githug,会提示游戏目录不存在,是否要创建一个,输入y然后回车: 根据提示cd git_hug 进入游戏目录,准备开始游戏。

基本命令

在开始前我们还需要了解游戏的一些基本操作:

  • play - 默认命令,检查是否过关
  • hint - 显示过关提示
  • reset - 重启本关,或者重启到指定的某关
  • levels - 显示关卡列表

来试一下,githug reset

示例

我以第一关为例子给大家演示一下玩法。

第一关的名称是:init,提示是:「一个新目录 git_hug 被创建了,请把它初始化为一个空仓库」。 假设现在我不知道该怎么过关,我可以查看过关提示: 指示是:「你可以输入 git 命令来查看 git 命令列表」。 看最后一行,原来用 git init 就可以初始化一个空仓库,接着输入 githug 进行过关检测:

太棒了!顺利进入第二关!

怎么样?明白了吗?后面的 54 关就靠你自己了哦!

友情提示

在闯关过程中,尽量使用 githug hintgit help subcommand 获取帮助,也可以根据下面的两个教程来系统学习。 猴子都能懂的 git 入门 廖雪峰的 git 教程

为保大家都能顺利通关,学到所有的知识点,接下来我会写过关攻略,详细介绍每一关的玩法。 并且我不会直接给答案,而是演示整个过关的过程。

祝你好运!我们明天见。


更新: 闯过这 54 关,点亮你的 Git 技能树(一) 闯过这 54 关,点亮你的 Git 技能树(二) 闯过这 54 关,点亮你的 Git 技能树(三)

请问为什么我安装完毕后提示找不到命令? zsh: command not found: githug

命令太容易敲错我都是用 git gui

#1 楼 @killernova 重新打开一个窗口试试呢?

45 关。表示不理解 git rebase -i HEAD~3 pick 一个 s 其它两个 过不去

#6 楼 @so_zengtao git rebase -i HEAD~4 pick 一个 s 3 个

#7 楼 @seabornlee get 到了 感觉是题目描述不清晰

👍 过了一遍之后发现我 git add 用的很 low

可参考:Githug 通关全攻略

几年前写的,可能有变动

#10 楼 @siyang1982 我不准备直接给答案,想要和大家一起去探索找到答案。

很不错

刚刚接触 git 没多久,感觉棒棒的

不错。。。练练这个还是很有用的……

51 关 git revert HEAD~1 不对

命令太容易敲错我都是用 git gui

#17 楼 @seabornlee 同样的操作,居然不能通关.....ubuntu14.04 ...... 我 16 楼的操作的命令也是同样的意思.........也是不能通过..... 重来还是这样......

#19 楼 @oreo 这是个 bug,在 Linux 平台的 git 2.5 或 2.6 版本上出现。不过好消息是这个 bug 昨天应经被修复了,gem update githug 然后重新运行 githug 即可。

Q: githug reset 26 无法跳到第 26 关,是不是我输错了? A: 噢,原来是输入名字。githug reset pull 就能跳转了

好好玩

#20 楼 @fighterleslie thx 可以了.....我看很多人都通关了,原来都是用 mac 的.....

#21 楼 @zhanglintc 我第一次也输入关卡编号,可以尝试加一下这个功能,提个 PR。

更新前三十关过关指引。

#23 楼 @seabornlee 拖了半年,终于提了这个 PR. 现在回复这个帖子算不算挖坟啊。

需要 登录 后方可回复, 如果你还没有账号请 注册新账号