一、版本控制

版本控制(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. Qt之QFileDialog

    widget.h: #ifndef WIDGET_H #define WIDGET_H #include <QWidget> #include<QString> class W ...

  2. java秒杀系列(1)- 秒杀方案总体思路

    前言 首先,要明确一点,高并发场景下系统的瓶颈出现在哪里,其实主要就是数据库,那么就要想办法为数据库做层层防护,减轻数据库的压力. 一.简单图示 我用一个比较简单直观的图来表达大概的处理思路 二.生产 ...

  3. 分页方法需要参数(当前页数,总数据量,拿到query的值)

    class Pagination: def __init__(self, page_num, all_count ,params=None,per_num=10,max_show=11): " ...

  4. Pycharm 使用备忘

    1.打开方法定义 快捷方式:[ctrl+左键]或者[Ctrl+B] 如果点击之后,打开不是[.py]文件,而是[.pyi]文件,可以把下面红框的参数删掉. 2.设置文件开头默认注释 # *_* cod ...

  5. ApacheCN 大数据译文集 20211206 更新

    PySpark 大数据分析实用指南 零.前言 一.安装 Pyspark 并设置您的开发环境 二.使用 RDD 将您的大数据带入 Spark 环境 三.Spark 笔记本的大数据清理和整理 四.将数据汇 ...

  6. Nginx实现跨域配置详解

    主要给大家介绍了关于Nginx跨域使用字体文件的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍: 问题描述 今天在使用子域名访问根域名的CSS时,发现字体无法显示,在确保CSS和Font字 ...

  7. HTML图片轮播

    一.纯 CSS 实现图片轮播 引自原文作者:南张人 原文链接:https://blog.csdn.net/u011848617/article/details/80468463 理论基础 CSS3 a ...

  8. Android图表库hellocharts详解

    感谢大佬:https://www.cnblogs.com/huolongluo/p/5988644.html 因为项目需要搞一个折线图,按照日期显示相应的成绩,所以有了本文. 以前用过一次XCL-ch ...

  9. Embedded Python应用小结

    转载请注明来源:https://www.cnblogs.com/hookjc/ (1)初始化Python脚本运行环境 Py_Initialize(); (2) 脚本的编译 bytecode = Py_ ...

  10. linux上printf出带颜色字体

    转载请注明来源:https://www.cnblogs.com/hookjc/ 统一定义: #define NONE         "\033[m"  #define RED   ...