一、版本控制

版本控制(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. golang中的sync

    1. Go语言中可以使用sync.WaitGroup来实现并发任务的同步 package main import ( "fmt" "sync" ) func h ...

  2. 学习JAVAWEB第六天

    # 今日内容: 1. JavaScript: 1. ECMAScript: 2. BOM: 3. DOM: 1. 事件 ## DOM简单学习:为了满足案例要求 * 功能:控制html文档的内容 * 获 ...

  3. 2022.02.04 Day1

    前言 为日后的算法面试做准备,自己也很喜欢算法这个东西,每天3~5道题. 刷题 1.leetcode 209 长度最下的子数组 题目 长度最下的子数组 大致的意思是从数组中找到长度最小的数组,并且数组 ...

  4. C程序:年转化天

    突然想算算自己到底活了多少天了,e,就是纯属为了好玩,毕竟咱作为一名C初学者还是要多练练的- 为了好玩,加了个密码登陆的,密码是521,还有就是不太懂时间获取... 具体闰年的判断方法: 代码如下: ...

  5. Servlet Servlet的装载三种情况

    感谢原文作者:DaleyDC 原文链接:https://blog.csdn.net/sinat_32873711/article/details/53170342 Servlet的装载三种情况: 自动 ...

  6. 开源项目实现多线程下载 (xutils)

    public void download(View v){         EditText et_url = (EditText) findViewById(R.id.et_url);        ...

  7. Token+Redis实现接口幂等性

    一.什么是 幂等性 在编程中,幂等性的特点就是其任意多次执行的效果和一次执行的效果所产生的影响是一样的. 二.Token+Redis的实现思路 1.数据提交前要向服务的申请 token(用户登录时可以 ...

  8. springboot实现分布式锁(spring integration,redis)

    Springboot实现分布式锁(Spring Integration+Redis) 一.在项目的pom.xml中添加相关依赖 1)Spring Integration依赖 <dependenc ...

  9. 自定义带图片和文字的Button的排版--陈棚

    自定义button,动态加载图片与文字 [footView addSubview:btnAllChoose]; [btnAllChoose setTitle:str forState:UIContro ...

  10. Kubernetes GitOps 工具

    Kubernetes GitOps Tools 译自:Kubernetes GitOps Tools 本文很好地介绍了GitOps,并给出了当下比较热门的GitOps工具. 简介 在本文中,将回顾一下 ...