美文网首页
Git 日常使用常见问题 (一)

Git 日常使用常见问题 (一)

作者: sufun_wu | 来源:发表于2016-05-21 11:02 被阅读41次

开篇

如今,Git 大行其道,颇有一统天下之势。

如果你的技能树上 Git 和 Github 的图标还没有点亮的话,你都不好意思说你是程序员。

别说互联网企业,我接触到的许多传统企业都在从 SVN,Clear Case 等迁移到 Git 上,甚至大厂还会有一个团队去定制适合自己企业的 Git 服务器。

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

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

* 忽略某些文件

* 创建,删除分支

* 找到最后修改某行代码的人

* 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

如果遇到权限问题,请加上sudo:

sudo 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 hint,git help subcommand获取帮助,也可以根据下面的两个教程来系统学习。

猴子都能懂的 git 入门

廖雪峰的 git 教程

为保大家都能顺利通关,学到所有的知识点,接下来我会写过关攻略,详细介绍每一关的玩法。

并且我不会直接给答案,而是演示整个过关的过程。

祝你好运!我们明天见。

https://codingstyle.cn/topics/51

相关文章

  • Git 日常使用常见问题 (一)

    开篇 如今,Git 大行其道,颇有一统天下之势。 如果你的技能树上 Git 和 Github 的图标还没有点亮的话...

  • Git 日常使用常见问题 (二)

    今天我将带大家完成前十关。第一关在前文中已经完成,我们从第二关开始吧。 如对任何命令有疑问请看第一篇里的推荐教程。...

  • Git 日常使用常见问题 (三)

    闯过这 54 关,点亮你的 Git 技能树 (三) - 软件匠艺 - SegmentFault 今天我将带大家完成...

  • Git快速入门

    虽然日常工作中经常使用git,但是在面对一些特殊情况时仍会捉襟见肘。在这里整理一些常见操作和常见问题。对于更详细的...

  • 常用Git命令

    推荐《Pro Git中文|Pro Git英文》 每天都在使用 Git ,但是很多命令记不住。一般来说,日常使用只要...

  • Git日常使用

    一、分支的用法 查看当前分支:git branch 创建分支:git checkout -b dev 当前分支前会...

  • Git日常使用

    仓库配置-用户名和邮件 作用:在提交日志中显示提交者的用户名和邮件。 全局配置(所有git本地仓库如果没有单独的配...

  • Git日常使用

    前言 本次文章主要介绍git多人合作的时候如何使用分支开发,操作以sourcetree和终端结合使用。 创建分支比...

  • git 日常使用

    创建代码库 cd到某个目录,然后创建一个Git本地代码库 $ git init cd到某个目录,将其初始化为带名字...

  • git 日常使用

    根据git 的日常使用频率,总结了一下 1、克隆工程 git clone https://github.com/X...

网友评论

      本文标题:Git 日常使用常见问题 (一)

      本文链接:https://www.haomeiwen.com/subject/tmjnrttx.html