一、版本控制

版本控制(Revision contontrol)是一种在开发过程中用于管理修改历史,方便查看更改历史记录,备份以便恢复以前版本的软件工程的技术。

1.实现跨区域多人协同开发
2.追踪和记载一个或者多个文件的历史记录
3.组织和保护你的源代码和文档
4.统计工作量
5.并行开发,提高效率
6.跟踪记录整个软件的开发过程
7.减轻开发人员的负担,节省时间,同时降低人为错误

用于管理多人协同开发项目的技术

常见的版本控制工具

1.Git
2.SVN(Subversion)
3.CVS(Concurrent Versions System)
4.VSS(Micorosoft Visual SourceSafe)
5.TFS(Team Foundation Server)
6.Visual Studio Online

本地版本控制

记录每次更新,可以对每个版本做一个快照,或是记录补丁文件

集中版本控制 SVN

所有数据保存到服务器上,协同开发者从服务器上同步更新或者上传自己的修改

分布式版本控制 Git

所有的版本信息仓库全部同步到本地的每个用户,每个人都拥有全部的代码

Git与SVN最主要的区别

SVN版本库用的中英服务器,使用时需要从中央服务器获得最新版本,然后工作,完成工作后把自己做完的工作推送到中央服务器。

Git是分布式版本控制系统,没有中央服务器,每个人的电脑都是一个完整的版本库,工作的时候不需要联网。

Git是目前世界上最先进的分布式版本控制系统

二、安装Git

1.Git界面

1)Git Bash:Unix与Linux风格的命令行,使用最多,推荐最多
2)Git CMD:Windows风格的命令行
3)Git GUI:图形界面的Git,不建议初学者使用,尽量先熟悉常用命令

2.Git配置

Git相关配置文件
  1)git config --system --list 系统级
  Git\etc\gitconfig

  2)git config --global --list 全局
  C:\Users\Administratpr\.gitconfig

设置用户名和邮箱(必要的)
  1)git config --global user.name "username" 用户名
  2)git config --global user.email xxxxxxx@xx.com 邮箱

环境变量只是为了全局使用,安装时会自动配置

三、Git基本理论(核心)

1.工作区域

工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository 或 Git Directory)。
如果再加上远程的git仓库(Remote Directory)就可以分为四个工作区域。

  1)Workspace:工作区,平时存放项目代码的地方。
  2)Index/Stage:暂存区,用于临时存放变动,事实上只是一个文件,保存即将提交到文件列表的信息。
  3)Repository:仓库区(或本地仓库),安全存放数据的位置,这里面有提交的所有版本的数据。其中HEAD指向最新放入仓库的版本。
  4)Remote:远程仓库,托管代码的服务器,可以简单地认为是项目中用于数据交换的一台电脑。

ref:refs/heads/master 主分支

git的工作流程:
  1)在目录添加、修改文件;
  2)将需要进行版本管理的文件放入暂存区域; git add
  3)将暂存区域的文件提交到git仓库

git管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)

2.Git命令

上传
  1)暂存命令:git add 提交到暂存区
  2)提交命令:git commit -m 提交暂存区的东西到本地仓库

搭建本地仓库
  3)Git初始化:git init

克隆远程仓库
  4)Git项目克隆:git clone [url]

查看文件状态
  5)查询所有文件信息:git status
  6)查询指定文件信息:git status [文件名]

3.忽略文件

在主目录下建立“.gitignore”文件,此文件有以下规则
  1)忽略文件中的空行或以#开头的行将会被忽略
  2)可以使用Linux通配符,例如星号(*)代表任意多个字符,问号(?)代表一个字符,方括号[abc]代表可选字符范围,
        大括号({string1,string2})代表可选字符串。
  3)如果名称最前面有一个感叹号(!),表示例外规则,不被忽略。
  4)如果名称的前面是一个路径分隔符(/),表示要忽略此目录下的文件,而子目录不被忽略。
  5)如果名称的后面是一个路径分隔符(/),表示要忽略此目录下的该名称的子目录,而非文件。

四、Gitee码云安装及使用

1.注册gitee、github账号

2.设置本机绑定的SSH公钥,实现免密码登录!(免密码登录很重要)

公钥设置:进入c:\User\Adnubstrator\.ssh 目录

ssh-keygen :生成公钥

3.将公钥信息public key 添加到码云账户中即可

4.使用码云创建一个自己的仓库

五、IDEA集成Git

1.新建项目,绑定git

将我们远程的git文件目录拷贝到项目中即可

2.修改文件,使用IDEA操作git

3.提交测试

六、Git分支常用指令

1.列出所有本地分支

  git branch

2.列出所有远程分支

  git branch -r

3.新建一个分支,但依然停留在当前分支

  git branch [branch-name]

4.新建一个分支,并切换到该分支

  git checkout -b [branch]

5.合并指定分支到当前分支

  git merge [branch]

6.删除分支

  git branch -d [branch-name]

7.删除远程分支

  git push origin --delete [branch-name] git branch -dr [remote/branch]

Git——版本控制器概述的更多相关文章

  1. 新手向--git版本控制器

    body { width: 70%; border: 1px solid #ddd; outline: 1300px solid #fff; margin: 16px auto } body .mar ...

  2. 使用git版本控制器C#工程,git托管到GitHub和visual studio on line

    类比TFS, 托管到了VS online,为私有.GitHub上托管的代码为开源. 新建工程选择版本控制器"Git" VS online: 本地: GitHub,下载github ...

  3. 介绍Git版本控制器的使用

    Git 简介 Git 是什么?大家肯定会说不就是版本控制器嘛,是的Git是目前世界上最先进的分布式版本控制系统(没有之一). 1.那什么是版本控制器呢? 举个简单的例子,比如我们用Word写文章,那你 ...

  4. 【原创】Git版本控制器的基本使用

    关于git Git,是一个分布式版本控制软件.最初本是为了更好的管理Linux内核开发而被林纳斯·托瓦兹开发,后来因为项目开发中版本控制的强烈需求,而git也日趋成熟,最终成为了一个独立的版本控制软件 ...

  5. Git版本控制器的使用

    首先介绍一下什么是Git:git是目前最流行的版本控制系统,属于分布式版本控制器. 使用Git前先要在GitHub创建代码仓库,或者获取你要应用的GitHub的链接地址. 创建GitHub仓库这里就不 ...

  6. Git版本控制器使用总结性梳理

    Git为何物?Git 是什么?大家肯定会说不就是版本控制器嘛,是的Git是目前世界上最先进的分布式版本控制系统(没有之一).1)那什么是版本控制器?举个简单的例子,比如我们用Word写文章,那你一定有 ...

  7. git版本控制器

    Git 是一个开源的分布式版本控制系统 Google用于android 源代码的管理就是Git,  它支持离线工作, 本地提交可以稍后提交到服务器上. 众多的开源项目都使用 Git  作为版本控制系统 ...

  8. git - 版本控制器(本地仓库)

    本地创建仓库,然后进行管理.提交到本地仓库(不需要网络),提交到远程仓库(需要网络) 相对于svn为克隆方式,赋值的是整个仓库,svn只是复制的代码.   1.电脑新创建一个”本地仓库”空文件夹 2. ...

  9. Git分布式版本控制器使用

    前言: 使用Git版本控制器差不多有一年多的时间了,在这一年多的时间里对这个传说的的分布式版本控制工具有了一定的了解.在实战项目开发中,对关于如何在通过Git提交项目,以及如何使用Git命令对提交的文 ...

随机推荐

  1. 中文分词,自然语言处理器NLP。 六月份版本已上线。

    一,  没有对比,就没有伤害,我们分词的优势在哪里?走一波测试. 跑一下CaCl2,看看效果. 二   想要分什么词汇,自己自定义即可. 目前每个月都会出一个新的版本,主要是和金融相关的词汇. 这是6 ...

  2. java中的继承 和多态。

    package com.aaa.zxf.ajax.test; /** *一. java 中的继承和多态. * * 继承的特性? * 1.实现继承的方式 * A 如何建立继承关系(一个类继承于 另一个类 ...

  3. Atcoder ARC-062

    ARC062(2020.7.13) A 可以考虑直接同时扩大这次的两个票数,那么使得两数均大于之前位置的票数就是最优的,扩大的话直接除一下上取整即可. B 贪心即可. C 可以发现这个东西如果直接计数 ...

  4. idea2020.1版本的maven项目报包不存在,找不到包错误

    错误描述 idea创建maven项目,导入依赖都是成功,但是运行就会报找不到对应jar包的错误 解决办法: File -> Settings -> 搜索maven -> 展开mave ...

  5. Android API在线网站

    http://android-doc.com/reference/packages.html

  6. new方法实现原理

    new方法实现原理 完整的创建一个可用的对象:Person *p=[Person new]; new方法的内部会分别调用两个方法来完成3件事情: (1)使用alloc方法来分配存储空间(返回分配的对象 ...

  7. Ext原码学习之Ext.js

    1 // JavaScript Document 2 //定义全局Ext变量 3 var Ext = Ext ||{}; 4 Ext._startTime = new Date().getTime() ...

  8. CSS快速入门(四)

    目录 CSS快速入门(四) 浮动 float属性 clear属性 浮动解决的问题及其影响 解决父标签塌陷的方法 浮动案例 定位 什么是脱离文档流 定位的两种方法 position定位 static定位 ...

  9. js实现网页回弹小球效果

    直接上效果图 运行页面会首先弹出一个输入框,询问用户想要产生的小球数量,随后后台就会产生指定数量的小球,在页面中来回跳动,触碰到页面边框时,就会回弹,且产生的小球颜色随机,小球在页面中的位置随机,小球 ...

  10. 通过loganalyzer展示数据库中的日志

    一.安装mysql # yum -y install mariadb-server # systemctl enable --now mariadb && systemctl stat ...