请问git的发明者是谁

想请问下大家git的发明者是谁?还挺好用,而且现在大家都在用

“Git发明者就是Linux之父 - Linus Linus在1991年开创了Linux。 那个时候,世界各地的大神自发开始对Linux进行相关的代码维护。

很多人都知道,Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。
Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?
事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码
你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。
不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。
安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。
Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:
Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。
Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。
历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。

  • 你可以看下这个问题的回答https://ask.csdn.net/questions/1054267
  • 我还给你找了一篇非常好的博客,你可以看看是否有帮助,链接:git总结的笔记分享给大家,git常用命令。
  • 除此之外, 这篇博客: 使用Git将最新提交移至新分支中的 先前的大多数答案都是危险的错误提示! 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 不要这样做:

    git branch -t newbranch
    git reset --hard HEAD~3
    git checkout newbranch
    

    下次运行git rebase (或git pull --rebase )时,这3个提交将被从newbranch静默丢弃! (请参阅下面的说明)

    而是这样做:

    git reset --keep HEAD~3
    git checkout -t -b newbranch
    git cherry-pick ..HEAD@{2}
    
    • 首先,它丢弃最近的3次提交( --keep类似于--hard ,但更安全,因为失败而不是丢弃未提交的更改)。
    • 然后它分叉newbranch
    • 然后,将这3次提交重选到newbranch 。 由于它们不再被分支引用,因此可以使用git的reflog来做到这一点: HEAD@{2}HEAD以前引用2个操作的提交,即在我们1.检出newbranch和2.使用git reset以丢弃3次提交。

    警告:默认情况下已启用reflog,但是如果您手动禁用了reflog(例如,通过使用“裸露”的git存储库),则在运行git reset --keep HEAD~3后,您将无法取回3次提交git reset --keep HEAD~3

    不依赖引用日志的替代方法是:

    # newbranch will omit the 3 most recent commits.
    git checkout -b newbranch HEAD~3
    git branch --set-upstream-to=oldbranch
    # Cherry-picks the extra commits from oldbranch.
    git cherry-pick ..oldbranch
    # Discards the 3 most recent commits from oldbranch.
    git branch --force oldbranch oldbranch~3
    

    (如果您愿意,可以编写@{-1} -先前签出的分支-代替oldbranch )。


  • 您还可以看一下 李建祥老师的程序猿Git实战课程课程中的 如何进行分支管理小节, 巩固相关知识点