版本控制系统(Version Control System,VCS)是软件开发过程中用于管理源代码的工具。它可以帮助你跟踪代码的变更历史,方便回滚到之前的版本,以及协同多人共同开发。Git是当前最流行的版本控制系统之一,我们将以Git为例,介绍版本控制的基本概念和操作。

10.5.1. Git基本概念

在Git中,主要有以下几个基本概念:

  1. 仓库(Repository):仓库是用来存储项目代码的地方,包含了项目的所有文件和文件的变更历史。
  2. 提交(Commit):提交是对文件的一次修改,每次提交都会生成一个唯一的哈希值(如a3f6c9d),用于标识该提交。
  3. 分支(Branch):分支是代码的一个独立版本,可以在分支上进行修改和提交,而不会影响其他分支。主分支通常称为mainmaster
  4. 合并(Merge):合并是将一个分支的更改应用到另一个分支的操作。这通常用于将功能分支的更改合并到主分支。

10.5.2. Git基本操作

以下是一些常用的Git操作:

  1. 克隆仓库(Clone):将远程仓库复制到本地计算机。

    git clone <repository_url>
  2. 查看状态(Status):查看工作目录的状态,包括已修改、已暂存和未暂存的文件。

    git status
  3. 添加文件(Add):将文件添加到暂存区,以便在下次提交中包含这些更改。

    git add <file>

    若要添加所有修改过的文件,可以使用:

    git add .
  4. 提交更改(Commit):将暂存区中的更改提交到仓库。

    git commit -m "Commit message"
  5. 拉取更改(Pull):从远程仓库获取最新更改并合并到当前分支。

    git pull
  6. 推送更改(Push):将本地仓库的更改推送到远程仓库。

    git push
  7. 创建分支(Branch):创建一个新的分支。

    git branch <branch_name>
  8. 切换分支(Checkout):切换到指定分支。

    git checkout <branch_name>

    若要在切换分支的同时创建新分支,可以使用:

    git checkout -b <branch_name>
  9. 合并分支(Merge):将指定分支的更改合并到当前分支。

    git merge <branch_name>
    git branch -d <branch_name>

10.5.3. Git工作流示例

以下是一个使用Git进行协作开发的简单示例:

  1. 克隆远程仓库到本地计算机:

    git clone https://github.com/your-username/your-repository.git
  2. 创建并切换到新的功能分支:

    git checkout -b new-feature
  3. 对项目进行修改,然后将更改添加到暂存区:

    git add .
  4. 提交更改:

    git commit -m "Add new feature"
  5. 切换回主分支:

    git checkout main
  6. 从远程仓库拉取最新更改:

    git   pull
  7. 将新功能分支合并到主分支:

    git merge new-feature
  8. 将合并后的主分支推送到远程仓库:

    git push
  9. 删除本地的功能分支(如果不再需要):

    git branch -d new-feature

通过这个示例,你可以了解到如何使用Git进行基本的协作开发。实际项目中,你可能还需要处理合并冲突、回滚提交等高级操作。要深入了解Git,建议参考官方文档或其他教程。

总之,版本控制(如Git)是软件开发中的重要工具。掌握Git的基本概念和操作,可以帮助你更高效地管理代码和协同开发。在实际项目中,除了掌握基本操作,还需要根据项目需求灵活运用各种Git功能。

推荐阅读:

https://mp.weixin.qq.com/s/dV2JzXfgjDdCmWRmE0glDA

https://mp.weixin.qq.com/s/an83QZOWXHqll3SGPYTL5g

10.5. 版本控制(如Git)的更多相关文章

  1. 版本控制工具——Git常用操作(上)

    本文由云+社区发表 作者:工程师小熊 摘要:用了很久的Git和svn,由于总是眼高手低,没能静下心来写这些程序员日常开发最常用的知识点.现在准备开一个专题,专门来总结一下版本控制工具,让我们从git开 ...

  2. 版本控制工具Git工具快速入门-Linux篇

    版本控制工具Git工具快速入门-Linux篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.版本管理系统的介绍 1>.版本管理系统的特点 1.1>.自动生成备份: ...

  3. 版本控制工具Git工具快速入门-Windows篇

    版本控制工具Git工具快速入门-Windows篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 最近在学习Golang语言,之前的开发环境在linux上开发的,后来由于办公用的是w ...

  4. 10篇写给Git初学者的最佳教程(转)

    身为网页设计师或者网页开发者的你,可能已经听说过Git这个正快速成长的版本控制系统.它由GitHub维护:GitHub是一个开放性的.存储众人代码的网站.如果你想学习如何使用Git,请参考本文.在文章 ...

  5. 开源分布式版本控制工具 —— Git 之旅

    Git 主张的分布式代码库与文件快照的设计思想,相对于传统 CVS.SVN 等集中式.文件差异式版本控制工具是一种挑战与颠覆.Git 带来了离线提交.轻量级分支等诸多便利.不过,也有人质疑 Git 的 ...

  6. Android群英传神兵利器读书笔记——第二章:版本控制神器——Git

    本人一直是徐医生的真爱粉,由于参加比赛耽误了8天,导致更新得有点慢,大家见谅 2.1 Git的前世今生 Git是什么 Git安装与配置 2.2 创建Git仓库 Git init Git clone 2 ...

  7. Git版本控制:Git查阅、撤销文件修改和撤销文件追踪

    http://blog.csdn.net/pipisorry/article/details/47867097 查看文件的修改历史 git log --pretty=oneline 文件名 # 显示修 ...

  8. 版本控制工具 - Git

    版本控制工具 - Git 安装完成后,打开Git Bash,这是一个命令行工具,用于操作仓库和仓库的文件.你可以通过命令将已经存在的项目变成仓库,也可以重新创建一个新项目再通过命令将其变成仓库,还可以 ...

  9. 痞子衡嵌入式:备受开源社区推崇的分布式版本控制工具(Git)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是分布式版本控制工具Git. 1.为什么需要版本控制系统? 单人软件项目开发过程,往往很多功能都是逐步增加的,在代码开发过程中,有的时候功 ...

  10. 版本控制— SVN & git

    版本控制—— SVN & GIT 提问 什么是版本控制? 是能够一直监视代码文件的变更,并存储这些文件以便将来引用的一种机制(软件) 为什么要使用版本控制? (1)记录哪个开发人员做了变更 ( ...

随机推荐

  1. salesforce零基础学习(一百二十五)零基础学习SF路径

    本篇参考: https://boulder-bard-27f.notion.site/Salesforce-Learning-e990864695674f07b99a5f8955770bd4 本篇背景 ...

  2. Spring AOP——源码分析

    [阅读前提]:需了解 AOP 注解开发流程:链接 一.注解 @EnableAspectJAutoProxy 在配置类中添加注解@EnableAspectJAutoProxy,便开启了 AOP(面向切面 ...

  3. 【ACM算法竞赛日常训练】DAY5题解与分析【储物点的距离】【糖糖别胡说,我真的不是签到题目】| 前缀和 | 思维

    DAY5共2题: 储物点的距离(前缀和) 糖糖别胡说,我真的不是签到题目(multiset,思维) 作者:Eriktse 简介:19岁,211计算机在读,现役ACM银牌选手力争以通俗易懂的方式讲解算法 ...

  4. DevOps, HybridOps and AIOps浅谈

    DevOps, HybridOps and AIOps浅谈 DevOps的概念出现比较久了,很多的IT项目也都在实际的运用中.AIOps概念作为DevOps的升级版,也得到了很广大的关注,也出现了很多 ...

  5. vue中实现video的动态src绑定

    Vue中实现video的动态src 试了网上的$refs方法发现并没有用 解决方案: 通过require方法  <div>     <video :src='url' @click= ...

  6. HaProxy 安装搭建配置

    HaProxy简介 HAProxy是一个免费的负载均衡软件,可以运行于大部分主流的Linux操作系统上. HAProxy提供了L4(TCP)和L7(HTTP)两种负载均衡能力,具备丰富的功能.HAPr ...

  7. [Java EE]缓存技术初探

    1 背景 使用场景:计算或检索一个值的代价很高,并且对同样的输入需要不止一次获取值的时候,就应当考虑使用缓存. 高并发下,为提高 频繁 查询 大量 可能常用的 数据库数据的 查询效率. 大部分情况下, ...

  8. pnpm 之降本增效

    作者:京东科技 于振京 受众简介 前端研发工程师 还在为npm i安装大量依赖等待时间较长,npm扁平化node_modules依赖版本冲突在苦恼吗,不用苦恼pnpm为你保驾护航 主要影响:安装依赖包 ...

  9. React+Antd在使用form表单提交DatePicker日期框的时候会出现少八小时的情况

    在使用antd做form表单提交的时候,突然发现了一个很有意思的bug.就是在使用datepicker组件日期框的时候会出现提交后少一天的问题 我在网上搜索了许多解决办法,也是困扰了我一天的时间,下面 ...

  10. docker启动mysql报错Can't read dir of '/etc/mysql/conf.d/'

    执行命令: docker run -p 3306:3306 --privileged=true -v /mysql/data:/var/lib/mysql -v /mysql/log:/var/log ...