Git学习之路

最开始使用Git的时候,学了 clone 和 pull 之后就觉得这样够用了,只是下载感兴趣的项目源码。

后来为了看源码在一段时间内有哪些改动,学了 log 、 show 和 diff 。

为了找到感兴趣内容所在的文件,学了 grep 。

接着发现上游有多个分支,为了查看不同分支,学了 branch 和 checkout (现在一般用 switch)。

因为上游用了 submodule 所以也稍微学了一下。

在网络不理想的时候,为了从镜像拉取,学了 remote 。

因为手痒,想自己给项目添加内容,为了让自己写的东西纳入 git 管理,学了 commit (那时候用的还是 commit -a ,用不到 add)。

大概是这时候,第一次遇到了躲不开的配置项,也就是 config 。

从上游拉取时,为了不和自己写的东西冲突,学了 merge 、 add 和 status,后来又学了 fetch 和 rebase 。

为了提 Pull Request,也为了备份自己写的东西,学了 push 。

为了把其他分支的修改转移到当前分支,学了 cherry-pick 。

为了撤回修改,学了 reset (当时的需求现在可以用 restore 完成)。

为了恢复不慎删除的内容,学了 reflog 。

为了保存写到一半的内容,学了 stash 。

为了找到引入或修复 bug 的版本,学了 bisect 和 blame 。

为了知道最近的 tag 名称,学了 describe 。

为了知道 tag 对应的提交代码,学了 rev-parse 。

(以上两条是为了更方便地 blame 。)

为了同时访问多个分支,学了 worktree 。

为了降低索引的大小,学了 gc 、 prune 和 repack 。

最近还学到用 ls-files 查看自己改了哪些文件。

当然过程中也断断续续学了不少选项,比如 commit --amend 、pull --rebase 、rebase --autostash、commit --fixup 、rebase --autosquash 等。

到这里我觉得我已经认识了大多数初级指令。但是对于如何使用 hook,如何直接操作索引中的对象,我还是一无所知。对于使用邮件的工作流程,我也不太了解。

回想起来,从一开始到现在,学的每个东西都是为了能用就行。

但是因为有这么多需要,也确实只有学习这么多东西才够用。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • windows 使用git & mac 使用git 1. 创建文件夹workspace 2.进入要管理的目录 右键...
    Bates阅读 262评论 0 2
  • 目录 clone add commit checkout pull push branch reset diff ...
    楼上那位阅读 423评论 0 0
  • 常用单词 HEAD --> 当前版本(HEAD^ --> 上一个版本,HEAD^^ --> 上上版本,HEAD~1...
    Anancncn阅读 170评论 0 1
  • svn cvs 集中式版本管理 git 分布式 1:简单介绍:把改动推入(Push)到上游版本库(upstrea...
    偶尔小高兴阅读 987评论 0 1
  • git 本地基本命令
    七宝qb阅读 241评论 0 0