Git的使用

**

Git命令使用及tortoiseGit使用

**
Git是目前世界上最先进的分布式版本控制系统,首先,了解下什么是集中式和分布式。

        集中式: – 版本库是集中存放在中央服务器的 – 最大的毛病就是必须联网才能工作 (Git的先前版本CVS及SVN都是集中式的版本控制系统)
        分布式:分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。 分布式版本控制系统的安全性要高很多。

1、安装git(windows)
  官网下载安装即可
  dos下键入git,有提示信息安装成功
  接着需要配置name和email:
  命令行键入: $ git config --global user.nameYour Name
  $ git config --global user.email “email@example.com
    (用了–global参数,表示你这台机器上所有的Git仓库都会使用这个配置,
    当然也可以对某个仓库指定不同的用户名和Email地址。)


2、git使用(常用)
  -创建版本库:
    --选择一个合适的地方,创建一个空目录
    --通过git init命令把这个目录变成Git可以管理的仓库(repository)
    --可以发现当前目录下多了一个.git的隐藏目录,删除这个.git则这个目录的取消跟踪
    --再明确一下,所有的版本控制系统,其实只能跟踪文本文件的改动

  -新建一个文件:写入一些内容:   git is a version control system.
                    git is free software.

  命令:git add readme.txt------把文件readme.txt添加到repository仓库
  命令:git commit -m “说明信息”------光是添加到仓库并没有结束,必须提交至仓库----说明信息
     有一个参数可不写它

  Tips:因为commit可以一次提交很多文件,所以可以多次add不同的文件,及一次add多个文件
      git add file1.txt
      git add file2.txt file3.txt
      git commit -m “add 3 files.”

再次修改文件后,使用git status命令
  命令:git status------查看当前仓库状态
每次修改文件后,都可以add并commit给仓库(映射为一次快照)
  命令:git diff------查看具体修改了什么内容,一般在文件修改后先git diff查看改了什么内容,在进行add和commit

不断对文件进行修改,然后不断提交修改到版本库里,类比游戏的存档
  命令:git log------查看"存档",只会显示当前"存档"之前的log,而若已经回到以前的版本,当版本的未来版本是查不到的(可以用git reflog)
    git log --pretty=oneline------显示为一行
    "commit e47…"为版本的commid id
  命令:git reflog------可以查看之前所有的版本文件
  命令:git reset --hard HEAD^------HEAD指向master,HEAD后边的一个 ^ 表示回溯到HEAD之前一个版本,数量=回溯个数,回溯较多的时候:HEAD~45。 或者通过git reflog拿到id:git reset --hard commit e084…


  分支与合并

  在版本回退里,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。HEAD严格来说不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是当前分支。
  一开始的时候,master分支是一条线,Git用master指向最新的提交,再用HEAD指向master,就能确定当前分支,以及当前分支的提交点,每次提交,master分支都会向前移动一步,这样,随着你不断提交,master分支的线也越来越长。
  当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上。从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变。

  假如我们在dev上的工作完成了,就可以把dev合并到master上。合并完分支后,甚至可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了一条master分支。

  首先,我们创建dev分支,然后切换到dev分支。
    命令:git checkout -b dev
    加上-b参数表示创建并切换,相当于以下两条命令:
      git branch dev
      git checkout dev
    命令:git branch------列出所有分支,当前分支前面会标一个*号
    然后,我们就可以在dev分支上正常提交,比如对readme.txt做个修改。–> 提交(add-commit)
    dev的分支工作完成,我们可以切换回master分支  -->  git checkout master

    切换回master分支后,再查看一个readme.txt文件,刚才添加的内容不见了。因为那个提交是在dev分支上,而master分支此刻的提交点并没有变。
    现在,我们把dev分支的工作成果合并到master分支上。
    命令:git merge dev------以当前分支为主,将dev分支合并到当前分支(dev–>(合入)master)
    合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。
合并完成后,就可以放心地删除dev分支了:  git branch -d dev

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值