Git版本控制(1)
来源:互联网 发布:sql in 多个字段 编辑:程序博客网 时间:2024/06/03 13:31
很早就听说github,但做的项目一直都很小(课程设计级别),根本不需要版本控制。但是现在没有用到,不代表以后不会用到,而且掌握版本控制的技巧也是许多公司的招聘要求之一,我也是学习廖雪峰老师教程后写下这些博文,顺便总结一下。
集中式vs分布式
Linus一直痛恨的CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制系统,集中式和分布式版本控制系统有什么区别呢?
先说集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
那分布式版本控制系统与集中式版本控制系统有何不同呢?首先,分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
安装Git
我在Mac OS X上安装了Git,Xcode集成了Git。
创建版本库
什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录:
$ mkdir learngit$ cd learngit$ pwd/Users/zhangyu/learngit
通过git init命令把这个目录变成Git可以管理的仓库:
$ git initInitialized empty Git repository in /Users/zhangyu/learngit/.git/
一个空的仓库(empty Git repository)瞬间就建好。
现在我们编写一个readme.txt文件,放到learngit目录下(子目录也行),内容如下:
Git is a version control system.Git is free software.
把一个文件放到Git仓库只需要两步,第一步,用命令git add告诉Git,把文件添加到仓库:
$ git add readme.txt
第二步,用命令git commit告诉Git,把文件提交到仓库:
$ git commit -m "wrote a readme file"[master (root-commit) cb926e7] wrote a readme file 1 file changed, 2 insertions(+) create mode 100644 readme.txt
简单解释一下git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。git commit命令执行成功后会告诉你,1个文件被改动(我们新添加的readme.txt文件),插入了两行内容(readme.txt有两行内容)。
时光机穿梭
我们稍微修改一下readme.txt文件:
Git is a distributed version control system.Git is free software.
git status命令可以让我们时刻掌握仓库当前的状态,下面的命令告诉我们,readme.txt被修改过了,但还没有准备提交的修改。
$ git status# On branch master# Changes not staged for commit:# (use "git add <file>..." to update what will be committed)# (use "git checkout -- <file>..." to discard changes in working directory)## modified: readme.txt#no changes added to commit (use "git add" and/or "git commit -a")
虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。比如你休假两周从国外回来,第一天上班时,已经记不清上次怎么修改的readme.txt,所以,需要用git diff这个命令看看:
$ git diff readme.txt diff --git a/readme.txt b/readme.txtindex 46d49bf..9247db6 100644--- a/readme.txt+++ b/readme.txt@@ -1,2 +1,2 @@-Git is a version control system.+Git is a distributed version control system. Git is free software.
可以从上面的命令输出看到,我们在第一行添加了一个“distributed”单词。
然后我们将新修改的文件提交到仓库中,一样是执行上文中提交新文件的那两步,在add之后commit之前,我们先查看一下git status的状态:
$ git status# On branch master# Changes to be committed:# (use "git reset HEAD <file>..." to unstage)## modified: readme.txt#
git status告诉我们,将要被提交的修改包括readme.txt,然后是commit之后的状态:
$ git status# On branch masternothing to commit (working directory clean)
Git告诉我们当前没有需要提交的修改,而且,工作目录是干净(working directory clean)的。
- Git版本控制(1)
- (1)版本控制工具之Git
- GIT 版本控制软件(-)
- Git 版本控制
- git 版本控制
- 版本控制 git 应用
- 版本控制Git
- git版本控制
- 版本控制软件Git
- Git 版本控制
- git-svn 版本控制
- 版本控制与git
- 分布式版本控制---Git
- Git 版本控制
- 版本控制:git
- GIT版本控制
- 版本控制--Git
- Git版本控制
- 后科技时代--处理器的思考
- 后科技时代--操作系统的思考
- C# DataGridView 获取当前单元格输入内容
- 集中式和分布式版本控制系统
- 机器学习核函数的定义和作用
- Git版本控制(1)
- 浅谈android6.0的新特性之运行时权限处理解析
- 2017寒假学习总结
- 怎样编写高质量的C代码----你真的会么???
- C++运算符重载
- Miracast/鼠标显示的那些事
- Python之strip与split函数
- JavaFX的ResourceBundle使用
- UVA 10474 Where is the Marble(stl,sort)