Git

1. 定义

Git是Linus Torvalds(Linux内核创始人)为了帮助管理Linux内核开发而开发的一个开放源码的分布式版本控制软件 ,它不同于Subversion、CVS这样的集中式版本控制系统 在集中式版本控制系统中只有一个仓库(repository),许多个工作目录(working copy),而像Git这样的分布式版本控制系统中 (其他主要的分布式版本控制系统还有Mercurial、GNU Arch、SVK等),每一个工作目录都包含一个完整仓库 ,它们可以支持离线工作,本地提交可以稍后提交到服务器上。分布式系统理论上也比集中式的单服务器系统更健壮,单服务器系统一旦服务器出现问题整个系统就不能运行了,分布式系统通常不会因为一两个节点而受到影响。
因为Android是由kernel、Dalvik、Bionic、prebuilt、build等多个Git项目组成,所以Android项目编写了一个名为Repo的Python的脚本来统一管理这些项目的仓库,使得Git的使用更加简单。

 

2. 相比Subversion的优势
(1)更方便的 Merge
分布式管理必然导致大量的Branch和Merge操作,因此分布式版本控制系统都特别注意这方面。在传统的CVS里面制作Branch和Merge简直就是噩梦,Subversion 作为一个用于替代CVS的系统,专门改进了Branch操作。然而似乎人们没有注意到,Branch是轻松了,可是Merge呢?如果不能很方便地Merge回来,做Branch仍然是噩梦。事实上,我就经历过在开发团队里面由于队友操作不对而在Merge的时候把我的许多代码都覆盖掉了。当时正是使用的subversion。虽然源代码仍然在历史里面,但是要去一个一个地找出被覆盖掉的文件并恢复过来确实是一件很难忘的事情。
(2)更方便的管理
传统的版本控制系统使用中央仓库,仓库相关的管理就只能在中央仓库上进行。赋予开发团队每一个人中央仓库的管理权限是非常不好的
(3)更健壮的系统
分布式系统一般情况下总是比单服务端的系统要健壮,因为单服务端一旦服务器挂掉了整个系统就不能运行了。然而分布式系统通常不会因为一两个节点而受到影响。
(4)对网络的依赖性更低
虽然现在网络非常普及,但是并不是随时随地都有高速网络。低速的网络会让人心情烦躁,有时候就呆呆地盯着屏幕上的commit进度什么事情也干不了。而没有网络连接更是致命的:你无法commit!这表示你进行任何改动以前都必须小心翼翼,否则你可能再也找不会你曾经写的一些代码了。
(5)更少的“仓库污染”
有时候你要做一个模块,它不是太大,所以没有必要为它新建一个 branch ,但是它又不是那么小,不可能一次提交就做好。于是便会提交一些不完整的代码到仓库,有时候会导致整个程序无法运行,严重影响团队里其他人的开发。大多数人在这种情况下的解决办法都是写完之后再提交。但是作为习惯了版本控制的人来说,进行不计后果的大幅修改是经常的事情,到后来突然发现自己先前的代码没有提交,就后悔莫及了。如果是分布式系统的话就不会存在这样的问题,因为本地仓库的修改不会影响到别人的仓库。当你完成并测试以后,就可以在邮件列表里面说:我已经把这个模块做好了。然后感兴趣的人就可以从你这里pull你的成果了。

 

3. 下载android源码

http://rubynroll.iteye.com/blog/203133

http://www.iteye.com/topic/476635

http://www.williamhua.com/2009/04/29/git-and-repo-for-dummies/

http://ghostsun.iteye.com/blog/352721

你可能感兴趣的:(Others,Git,Android,subversion,CVS,Linux)