版本控制工具之Git的基础使用教程

news2024/11/21 0:23:31

Git

Git是一个分布式版本控制系统,由Linux之父Linus Torvalds 开发。它既可以用来管理和追踪计算机文件的变化,也是开发者协作编写代码的工具。

本文将介绍 Git 的基础原理、用法、操作等内容。

一、基础概念

1.1 版本控制系统

版本控制系统(Version Control System,VCS)是一种管理代码或文档变更的软件。VCS 可以帮助开发者记录、查看、比较、合并和恢复文件的版本。常见的 VCS 有 Git、Subversion(SVN)、Perforce 等。

1.2 Git

Git 是一个开源的分布式版本控制系统,由 Linus Torvalds 于 2005 年创建。与集中式版本控制系统不同,Git 是一种分布式版本控制系统,意味着每个开发者都拥有一个完整的代码库,可以在本地进行代码的版本控制和修改。与其他 VCS 相比,Git 具有以下优势:

  • 高效性:Git 使用一种名为快照(Snapshot)的方式来存储版本,而不是基于差异的方式,因此在合并分支等操作上更加高效。
  • 分布式:与集中式版本控制系统不同,每个Git工作目录都是一个完整的仓库,拥有完整的历史记录和版本追踪能力,不依赖于网络连接或中心服务器。
  • 分支管理:Git的一个核心特点是强大的分支管理系统。在Git中创建新的分支、合并分支、删除分支都非常简单,极大提高了开发者进行并行开发的效率。
  • 安全性:Git 有完整的 SHA-1 哈希校验机制,保证文件内容不被篡改。
  • 开源: Git是免费和开放源代码的,任何人都可以查阅代码来了解其工作原理或者根据需求进行修改。

1.3 Git 的工作流程

Git 的工作流程可以分为三个阶段:工作目录(Working Directory)、暂存区(Staging Area)和版本库(Repository)。其中,工作目录是指本地的工作区,用于进行开发工作,暂存区是一个缓存区,用于存放待提交的修改,版本库则是存放完整历史版本的地方。

工作区(Working Directory):这是你电脑上可见的,实际处理的文件。这些文件可能是已经修改的或尚未加入Git的版本控制。

暂存区(Staging Area 或 Index):英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。通过git add 命令可以增加文件到暂存区,使用 git rm 命令可以从暂存区删除文件,使用 git commit 命令, 将暂存区的文件提交到Git仓库。

版本库:工作区有一个隐藏目录 .git,这个不算工作区,而是 Git 的版本库。

下面是一个简单的 Git 工作流程示意图:

二、Git 的安装和配置

2.1 Git 的安装

在 Windows 和 macOS 系统中,可以直接从 Git 官网下载安装程序进行安装(这里就不讲解了因为网上有很多安装教程)。在 Linux 系统中,可以使用系统包管理器进行安装,例如在 Ubuntu 系统中,可以使用以下命令进行安装:

$ sudo apt-get update
$ sudo apt-get install git

2.2 Git 的配置

安装完 Git 后,需要进行一些基本的配置,可以通过以下命令设置用户名和邮箱:

$ git config --global user.name "Your Name"
$ git config --global user.email "your.email@example.com"

还可以通过以下命令来设置默认文本编辑器和比较工具:

$ git config --global core.editor vim
$ git config --global merge.tool vimdiff

三、Git 的常用命令

3.1 创建仓库

在 Git 中,可以使用 git init 命令创建一个新的仓库。

例如,要在当前目录下创建一个名为 myrepo 的新仓库,可以使用以下命令:

$ mkdir myrepo
$ cd myrepo
$ git init

3.2 添加文件

在 Git 中,可以使用 git add 命令将文件添加到暂存区。例如,要将当前目录下的 index.html 文件添加到暂存区,可以使用以下命令:

$ git add index.html

如果要将当前目录下的所有文件添加到暂存区,可以使用以下命令:

注意一定要加后边的 “点”

$ git add .

3.3 提交修改

在 Git 中,可以使用 git commit 命令将暂存区的修改提交到版本库中。

例如,要将暂存区的修改提交并添加一条提交信息,可以使用以下命令:

$ git commit -m "Add index.html"

3.4 查看状态

在 Git 中,可以使用 git status 命令查看当前仓库的状态。

例如,要查看当前仓库的状态,可以使用以下命令:

$ git status

3.5 查看提交历史

在 Git 中,可以使用 git log 命令查看提交历史。

例如,要查看当前仓库的提交历史,可以使用以下命令:

$ git log

3.6 分支管理

在 Git 中,可以使用 git branch 命令管理分支。

例如,要创建一个名为 dev 的新分支,可以使用以下命令:

bash
$ git branch dev

要切换到 dev 分支,可以使用以下命令:

$ git checkout dev

3.7 合并分支

在 Git 中,可以使用 git merge 命令将一个分支的修改合并到当前分支中。

例如,要将 dev 分支的修改合并到当前分支中,可以使用以下命令:

$ git merge dev

3.8 撤销修改

在 Git 中,可以使用 git checkout 命令撤销对文件的修改。

例如,要撤销对 index.html 文件的修改,可以使用以下命令:

$ git checkout index.html

3.9 远程仓库

在 Git 中,可以使用 git remote 命令管理远程仓库。

例如,要添加一个名为 origin 的远程仓库,并将其指向一个 URL,可以使用以下命令:

$ git remote add origin https://github.com/username/myrepo.git

要将本地仓库的修改推送到远程仓库,可以使用以下命令:

$ git push origin master

其中 origin 是远程仓库的名称,master 是要推送到远程仓库的分支名称。

要从远程仓库中获取最新的代码,可以使用以下命令:

$ git pull origin master

其中 origin 是远程仓库的名称,master 是要拉取的分支名称。

3.10 其他常用命令

git clone:从远程仓库克隆一个本地仓库。

git diff:查看两个版本之间的差异。

git reset:撤销最近的提交,并将修改移动到暂存区。

git revert:撤销指定的提交,并创建一个新的提交来表示该撤销操作。

四、Git 的工作流程

Git 的工作流程包括以下几个步骤:

  1. 初始化仓库:使用 git init 命令将当前目录初始化为一个 Git 仓库。

  2. 添加文件:使用 git add 命令将修改的文件添加到本地仓库的暂存区中。

  3. 提交变化:使用 git commit 命令将暂存区中的修改提交到本地仓库中,并创建一个新的版本记录。

  4. 查看状态:使用 git status 命令查看当前仓库的状态,包括已修改的文件、已添加到暂存区的文件、未跟踪的文件等。

  5. 查看日志:使用 git log 命令查看当前仓库的提交历史记录,包括作者、时间戳、提交说明等信息。

  6. 远程操作:使用 git remote 命令管理远程仓库,并使用 git pushgit pull 命令与远程仓库进行同步操作。

  7. 分支管理:使用 git branch 命令创建、查看、切换和删除分支,以支持并行开发和版本控制。

  8. 解决冲突:当多个开发者同时修改同一个文件时,可能会产生冲突。使用 git mergegit rebase 命令解决冲突,将修改合并到一个版本中。

以下是一个典型的 Git 工作流程示例:

#从远端仓库克隆项目到自己电脑
$ git clone https://github.com/username/myrepo.git
$ cd myrepo
# 在本地仓库中进行修改
$ git add .
$ git commit -m "Add new feature"
$ git push origin master
# 从远程仓库中拉取最新的代码
$ git pull origin master

五、常见问题解答

6.1 如何解决冲突?

在协作开发过程中,当两个开发者修改了同一个文件的同一行代码时,就会发生冲突。解决冲突的方法通常有以下几种:

手动解决冲突:手动合并两个开发者的代码,并提交修改到版本库中。

使用 Git 的合并工具:Git 自带了合并工具,可以使用以下命令进行合并:git mergetool

使用 Git 的补丁功能:可以使用以下命令将差异保存为补丁文件,然后将补丁文件发送给其他开发者进行合并:git diff > patchfile

6.2 如何撤销提交?

如果提交的代码有问题,可以使用以下命令进行撤销:

撤销最近的提交,并将修改移动到暂存区:git reset HEAD~

撤销最近的提交,并将修改移动到工作目录:git reset HEAD~ --hard

6.3 如何删除文件?

要删除文件,可以使用以下命令:

$ git rm filename
$ git commit -m "Delete filename"
$ git push origin master

其中 filename 是要删除的文件名称。

6.4 如何切换分支?

要切换分支,可以使用以下命令:

$ git checkout branchname

其中 branchname 是要切换到的分支名称。

6.5 如何创建标签?

要创建标签,可以使用以下命令:

$ git tag -a v1.0 -m "Version 1.0"
$ git push origin v1.0

其中 v1.0 是标签名称,Version 1.0 是标签说明。

6.6 如何查看提交历史?

要查看提交历史,可以使用以下命令:

$ git log

该命令会列出所有的提交历史记录,包括提交 ID、提交者、提交时间、提交说明等信息。

六、总结

Git 是一款强大的版本控制工具,可以帮助开发人员管理代码、协作开发以及备份代码等任务。本文介绍了 Git 的原理、用法和常用命令,并且介绍了 Git 的工作流程。希望本文对初学者能够提供帮助,让大家能够更好地使用 Git。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1656954.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何区分APP页面是H5还是原生页面?

刚刚接触手机测试的同学,或多或少都有过这样的疑问:APP页面哪些是H5页面?哪些是原生页面?单凭肉眼,简直太难区分了!我总结了6个小技巧,希望能帮大家答疑解惑。 1、看断网的情况 断开网络,显示…

推荐 3 个 yyds 的开源项目!

本期推荐开源项目目录: 1. AI 搜索引擎 2. 大模型聊天框架 3. 模仿抖音的移动端短视频 01 AI 搜索引擎 Perplexica 是一个开源的、由 AI 驱动的搜索引擎。它深入互联网寻找答案,不仅搜索网络,还理解您的问题。 Perplexica 受到 Perplexity AI…

今天来聊聊Numpy!

numpy?what~什么是numpy? 小编先暂且不提。 ​ 大家先暂且看看这句话,“你给我翻 译翻译,什么他妈的是他妈的惊喜? 这还用翻译,都说了… 惊喜嘛……”。 惊喜这段出自《让子…

Could not find the Qt platform plugin “dxcb“ in ““、 重点:是dxcb

这个重点就在于是dxcb不是xcb,让我一顿好找。 https://bugs.launchpad.net/ubuntu/source/deepin-qt5dxcb-plugin/bug/1826629 这篇文章描述了应该是deepin系统的一个问题,应该已经修复了不知道为什么我还会遇到。 不过知道是dxcb后直接去qtcreater里的系…

ICode国际青少年编程竞赛- Python-2级训练场-坐标与列表遍历

ICode国际青少年编程竞赛- Python-2级训练场-坐标与列表遍历 1、 for i in range(5):Flyer[i].step(Dev.x -Flyer[i].x) Dev.step(Item.y - Dev.y)2、 for i in range(7):Flyer[i].step(Dev.y - Flyer[i].y) Dev.step(Item[2].x - Dev.x)3、 for i in range(5):Flyer[i].…

基于若依框架搭建网站的开发日志(一):若依框架搭建、启动、部署

RuoYi(基于SpringBoot开发的轻量级Java快速开发框架) 链接:开源地址 若依是一款开源的基于VueSpringCloud的微服务后台管理系统(也有SpringBoot版本),集成了用户管理、权限管理、定时任务、前端表单生成等…

MYSQL8.0.20安装教程

一:下载mysql MySQL :: Download MySQL Installer (Archived Versions) 二:选中server only,点击next 三:点击server 选项,点击Execute 弹窗点击安装 四:安装项为绿色后,点击next 五&#xf…

大数据中的HDFS读写流程(namenode,datanode)

HDFS读写流程 读取流程 1、客户端请求上传文件 2、namenode检查是否存在,可以上传, 3、客户端请求第一个block块上传到datanode 4、namenode返回3个datanode节点,d1,d2,d3 5、客户端请求dn1调用数据,d1收到请求会继续调用d2&#…

使用海外云手机为亚马逊店铺引流

在全球经济一体化的背景下,出海企业与B2B外贸企业愈发重视海外市场的深耕,以扩大市场份额。本文旨在探讨海外云手机在助力亚马逊店铺提升引流效果方面的独特作用与优势。 海外云手机,一种基于云端技术的虚拟手机,能够在单一硬件上…

经典分类网络LeNet5和VGG16项目:实现CIFAR10分类

CIFAR10分类 v1:LeNet5:2cnn3fc 可视化结果 精确率 损失 最佳 v2:LeNet5:3cnn2fc 可视化结果 精确率 损失 最佳 v3:LeNet5:2cnnbnres3fc 可视化结果 精确率 损失 最佳 v4:VG…

web API设计笔记

Hello , 我是小恒。今晚就讲讲我在开发维护API后的经验分享,当然我知识有限,暂时也不会写实际操作。GitHub项目仓库有一堆还在前期开发,我的时间很多时间投在了开源上。 推荐书籍 我认为一个好的 API 设计是面向用户的,充分隐藏底…

2024华为数通HCIP-datacom最新题库(变题版)

请注意,华为HCIP-Datacom考试831已变题 请注意,华为HCIP-Datacom考试831已变题 请注意,华为HCIP-Datacom考试831已变题 近期打算考HCIP的朋友注意了,如果你准备去考试,还是用的之前的题库,切记暂缓。 H1…

IDEA切换分支

1、选择要切换分支的module 2、右键,选择git 3、再点击branches 4、可以看到当前module的本地分支(local Branches)及远程分支(Remote Branches)列表。点击你要切换到的分支,Checkout即可。

01WPS部分编写实现QT

1、新建项目 -创建wps类 -继承QMainWindow 2、菜单栏设置 3、开始实现操作 设置程序图标: pro文件中添加 RC_ICONS images/wps.ico //后面这个是文件地址哈1、字体选择大小设置 void MainWindow::initMainWindow() {// 初始化字号列表项QFontDatabase fontdb;…

Sarcasm detection论文解析 |# 利用情感语义增强型多层次记忆网络进行讽刺检测

论文地址 论文地址:https://www.sciencedirect.com/science/article/abs/pii/S0925231220304689?via%3Dihub#/ 论文首页 笔记框架 利用情感语义增强型多层次记忆网络进行讽刺检测 📅出版年份:2020 📖出版期刊:Neurocomputing 📈影…

预测市场?预测股票?如何让预测有更高的准确率?

我们发现在足球赛中,只要知道一个简单的讯息(主队过去的获胜机率超过一半),预测力就会明显好过随便乱猜。如果再加上第二个简单的讯息(胜负纪录较佳的队伍会略占优势),可以再进一步提升预测力。…

TinySeg:模型优化框架

TinySeg:模型优化框架 摘要Background & MotivationThe TinySeg Model OptimizerThe TinySeg RuntimeEvaluation TinySeg: Model Optimizing Framework for 摘要 图像分割是计算机视觉任务中的主要组成部分,适用于各种领域,如无人机的自主导航。然而…

合并果子

借助这一道题目来严谨证明一下Huffman树的构造方法的正确性 对任意一颗\(k\)叉huffman树,他都可以等价于一个类似于合并果子的过程,即每次取出最多\(k\)个点进行合并,然后\(k\)个点的权值和就是新的点的权值,然后把这个新的点加入…

5.9号模拟前端面试10问

5.9号模拟前端面试10问 1.html语义化的理解 HTML语义化是指使用具有明确含义的HTML标签来描述内容&#xff0c;而不仅仅是使用<div>和<span>等通用容器标签。语义化的HTML代码更易于阅读和维护&#xff0c;同时也有助于搜索引擎优化&#xff08;SEO&#xff09;。…

【微机原理及接口技术】存储器

【微机原理及接口技术】存储器 文章目录 【微机原理及接口技术】存储器前言一、半导体存储器技术1.半导体存储器概述2.半导体存储器的分类3.半导体存储器芯片的结构 二、半导体存储器芯片1.RAM芯片2.ROM芯片 三、半导体存储器与CPU的连接1.存储芯片数据线的连接2.存储芯片地址线…