玩转 Git 三剑客
苏玲
携程代码平台负责人
60828 人已学习
新⼈⾸单¥68
课程目录
已完结/共 62 讲
第三章:Git与GitHub的简单同步 (4讲)
第五章:Git集成使用禁忌 (2讲)
玩转 Git 三剑客
登录|注册
留言
27
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 11 | 小练习:数一数tree的个数
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | 课程综述
02 | 安装Git
03 | 使用Git之前需要做的最小配置
04 | 创建第一个仓库并配置local用户信息
05 | 通过几次commit来认识工作区和暂存区
06 | 给文件重命名的简便方法
07 | 通过git log查看版本演变历史
08 | gitk:通过图形界面工具来查看版本历史
09 | 探密.git目录
10 | commit、tree和blob三个对象之间的关系
11 | 小练习:数一数tree的个数
12 | 分离头指针情况下的注意事项
13 | 进一步理解HEAD和branch
14 | 怎么删除不需要的分支?
15 | 怎么修改最新commit的message?
16 | 怎么修改老旧commit的message?
17 | 怎样把连续的多个commit整理成1个?
18 | 怎样把间隔的几个commit整理成1个?
19 | 怎么比较暂存区和HEAD所含文件的差异?
20 | 怎么比较工作区和暂存区所含文件的差异?
21 | 如何让暂存区恢复成和HEAD的一样?
22 | 如何让工作区的文件恢复为和暂存区一样?
23 | 怎样取消暂存区部分文件的更改?
24 | 消除最近的几次提交
25 | 看看不同提交的指定文件的差异
26 | 正确删除文件的方法
27 | 开发中临时加塞了紧急任务怎么处理?
28 | 如何指定不需要Git管理的文件?
29 | 如何将Git仓库备份到本地?
30 | 注册一个GitHub账号
31 | 配置公私钥
32 | 在GitHub上创建个人仓库
33 | 把本地仓库同步到GitHub
34 | 不同人修改了不同文件如何处理?
35 | 不同人修改了同文件的不同区域如何处理?
36 | 不同人修改了同文件的同一区域如何处理?
37 | 同时变更了文件名和文件内容如何处理?
38 | 把同一文件改成了不同的文件名如何处理?
39 | 禁止向集成分支执行push -f操作
40 | 禁止向集成分支执行变更历史的操作
41 | GitHub为什么会火?
42 | GitHub都有哪些核心功能?
43 | 怎么快速淘到感兴趣的开源项目?
44 | 怎样在GitHub上搭建个人博客
45 | 开源项目怎么保证代码质量?
46 | 为何需要组织类型的仓库?
47 | 创建团队的项目
48 | 怎样选择适合自己团队的工作流?
49 | 如何挑选合适的分支集成策略?
50 | 启用issue跟踪需求和任务
51 | 如何用project管理issue?
52 | 项目内部怎么实施code review?
53 | 团队协作时如何做多分支的集成?
54 | 怎样保证集成的质量?
55 | 怎样把产品包发布到GitHub上?
56 | 怎么给项目增加详细的指导文档?
57 | 国内互联网企业为什么喜欢GitLab?
58 | GitLab有哪些核心的功能?
59 | GitLab上怎么做项目管理?
60 | GitLab上怎么做code review?
61 | GitLab上怎么保证集成的质量?
62 | 怎么把应用部署到AWS上?
本节摘要
登录 后留言

全部留言(27)

  • 最新
  • 精选
张伟明
看到这里我得出一个经验,没有文件也就是没有blob对象的目录是不会被git管理的,因为git要对文件进行版本管理,所以没有必要对空目录生成对象。基于这一点,readme文件的全路径是这样:[仓库根目录]/doc/readme。那么tree的数量与全路径中“/”的数量一致。

作者回复: 这个归纳有点意思

2019-02-22
3
31
维维
好像就是一个文件系统噢。一次 commit 创建一棵大树,commit 是 root 节点。这么看起来 git 的原理很简单。

作者回复: 简单的才美😄

2018-12-17
14
老师这里 我实验了一下,当提交一次,对一个文件生成一个 Blob 对象后,在对该文件进行修改提交 ,又会产生一个新的 Blob, 这里是不是对同一文件多次修改提交后,会产生多个 Blob 对象? 如果这样的话,那会不会越来越大,有点冗余?

作者回复: 你的理解都对,git也考虑到后面这个问题了,所以它会把松散的blob做整理,把内容相近的blob做增量存储。

2018-12-15
12
GS
老师讲得太棒了!深入到.git里面剖析一番,揭开了Git的神秘面纱,让我对Git的了解更进一步,也就没那么害怕他了。就像人与人之间,熟了就不怕了,老师的切入点真棒!

作者回复: Git设计得好,让我们走近它

2018-12-11
4
电光毛5号
如果不往readme文件中写入信息,加入暂存区后 Git是会创建一个空的blob对象 还是不创建呢

作者回复: 好问题。大家可以测试一下

2019-03-23
2
3
老师 tree 的产生必须 commit 吗?

作者回复: 好问题。我们测下来的结果说明是这样的。

2018-12-15
2
3
fatty Jack
老师请问下 最后那个小练习,为什么中间需要有2个tree,一个tree不可以吗?多个tree的原因是什么?

作者回复: 让blob成为基础组件,可以利用树把多个文件特定版本对应的blob进行灵活的组装。 blob(代表文件的内容)可以充分地被复用。

2019-04-11
2
啊波次的额佛哥~
老师可以这样理解吧,commit相当于根节点,blob相当于叶子节点存储文件值,其他的是tree节点。

作者回复: 就commit对应的项目所有文件的组织来说,可以这么理解

2019-01-17
1
ownraul
刚刚看了一下具体结构, 关于每个 commit 当次提交文件的区分, 是通过比较当次 commit 和 parent 中所有不同的 tree 和 blob , 然后计算出的当次 commit 涉及的文件么?

作者回复: 好问题,我整理清楚了再答复

2018-12-15
2
1
Jone_乔泓恺
老师:我按照您的例子事件了下,可是没有 doc 呀?直接就是 commit -> tree -> blob。这个原理是什么呢?

作者回复: doc是我们创建的文件夹,我们把 readme 文件放在这个文件夹下了。你再观察一下。

2020-12-22
2
收起评论