zoukankan      html  css  js  c++  java
  • Git02

    一、版本控制概要 工作区 暂存区 本地仓库 远程仓库

    1.1、什么是版本控制

    版本控制(Revision control)是一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。

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

    简单说就是用于管理多人协同开发项目的技术。

    没有进行版本控制或者版本控制本身缺乏正确的流程管理,在软件开发过程中将会引入很多问题,如软件代码的一致性、软件内容的冗余、软件过程的事物性、软件开发过程中的并发性、软件源代码的安全性,以及软件的整合等问题。

    1.2、常用术语

    1)、仓库(Repository)
    受版本控制的所有文件修订历史的共享数据库

    2)、工作空间(Workspace)
    本地硬盘或Unix 用户帐户上编辑的文件副本

    3)、工作树/区(Working tree)
    工作区中包含了仓库的工作文件。您可以修改的内容和提交更改作为新的提交到仓库。

    4)、暂存区(Staging area)
    暂存区是工作区用来提交更改(commit)前可以暂存工作区的变化。

    5)、索引(Index)
    索引是暂存区的另一种术语。

    6)、签入(Checkin)
    将新版本复制回仓库

    7)、签出(Checkout)
    从仓库中将文件的最新修订版本复制到工作空间

    8)、提交(Commit)
    对各自文件的工作副本做了更改,并将这些更改提交到仓库

    9)、冲突(Conflict)
    多人对同一文件的工作副本进行更改,并将这些更改提交到仓库

    10)、合并(Merge)
    将某分支上的更改联接到此主干或同为主干的另一个分支

    11)、分支(Branch)
    从主线上分离开的副本,默认分支叫master

    12)、锁(Lock)
    获得修改文件的专有权限。

    13)、头(HEAD)
    头是一个象征性的参考,最常用以指向当前选择的分支。

    14)、修订(Revision)
    表示代码的一个版本状态。Git通过用SHA1 hash算法表示的ID来标识不同的版本。

    15)、标记(Tags)
    标记指的是某个分支某个特定时间点的状态。通过标记,可以很方便的切换到标记时的状态。

    1.3、常见的版本控制器

    主流的版本控制器有如下这些:

    • Git
    • SVN(Subversion)
    • CVS(Concurrent Versions System)
    • VSS(Micorosoft Visual SourceSafe)
    • TFS(Team Foundation Server)
    • Visual Studio Online

    版本控制产品非常的多(Perforce、Rational ClearCase、RCS(GNU Revision Control System)、Serena Dimention、SVK、BitKeeper、Monotone、Bazaar、Mercurial、SourceGear Vault),现在影响力最大且使用最广泛的是Git与SVN

  • 相关阅读:
    Python 发送邮件
    python3 根据时间获取本月一号和月末日期
    docker搭建MediaWiki
    linux下僵尸进程的发现与处理
    rootkit后门检查工具RKHunter
    CentOS7安装Node_exporter(二进制)
    用JS获取地址栏参数的方法(超级简单)
    php读取目录及子目录下所有文件名的方法
    css input[type=file] 样式美化,input上传按钮美化
    APACHE REWRITE ? 匹配问号的写法
  • 原文地址:https://www.cnblogs.com/huaobin/p/14910242.html
Copyright © 2011-2022 走看看