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

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.mzph.cn/pingmian/9408.shtml

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

相关文章

Python-----容器的介绍以及操作

1.列表和元组 1.列表是什么, 元组是什么: 编程中, 经常需要使用变量, 来保存/表示数据. 如果代码中需要表示的数据个数比较少, 我们直接创建多个变量即可. 但是有的时候, 代码中需要表示的数据特别多, 甚至也不知道要表示多少个数据. 这个时候, 就需要用到列表 列表…

论文解读--High-resolution Automotive Radar Point Cloud Imaging and Processing

高分辨汽车雷达点云成像和处理 摘要 汽车雷达具有体积小、硬件成本低、全天候工作、高分辨率等公认的优点,是高级驾驶辅助系统(ADAS)必不可少的一类重要传感器。然而,低角度分辨率和低成像性能的限制很难满足下一阶段ADAS的需要。新兴的4D成像雷达采用多…

SSC369G 双4K高性价比AI IPC方案

一、方案描述 SSC369G 双4K高性价比AI IPC方案采用主芯片SSC369G,内核为CA55四核最高主频为1.5Ghz处理器。SOC内置集成一个64位的四核RISC处理器,先进的图像信号处理器(ISP),高性能的H.265/H.264/MJPEG视频编解码器&a…

每日OJ题_记忆化搜索⑤_力扣329. 矩阵中的最长递增路径

目录 力扣329. 矩阵中的最长递增路径 解析代码1_爆搜递归(超时) 解析代码2_记忆化搜索 力扣329. 矩阵中的最长递增路径 329. 矩阵中的最长递增路径 难度 困难 给定一个 m x n 整数矩阵 matrix ,找出其中 最长递增路径 的长度。 对于每…

Linux下多线程相关概念

thread 1.什么是线程1.1 线程优缺点1.2 线程异常1.3 线程用途 2. 进程和线程区别3. 线程控制3.1 POSIX线程库3.2 pthread_create()3.3 线程ID3.4 线程ID地址空间布局pthread_self() 3.5 线程终止pthread_exit函数pthread_cancle函数 3.6 线程等待3.7 分离线程__thread修饰全局变…

Spring Boot | Spring Boot 消息管理 ( 消息中间件 ) 、RabbitMQ“消息中间件“

目录: 一、"消息服务" 概述 :1.1 为什么要使用 "消息服务" ( 消息中间件 ) ?① 异步处理② 应用解耦③ 流量削峰④ 分布式事务管理 1.2 常用 "消息中间件" 介绍 :ActiveMQ ( 广泛应用于中小型企业 )RabbitMQ ( 没有特别要求的场景下…

如何利用SSL证书让IP实现HTTPS安全访问

在互联网日益发展的今天,数据安全与隐私保护成为了用户和企业共同关注的焦点。HTTPS(超文本传输安全协议)作为一种广泛采用的安全通信协议,通过加密数据传输,为网站访问提供了安全保障。然而,要实现HTTPS访…

uniapp百度地图聚合

// loadBMap.js ak 百度key export default function loadBMap(ak) {return new Promise((resolve, reject) > {//聚合API依赖基础库,因此先加载基础库再加载聚合APIasyncLoadBaiduJs(ak).then(() > {// 调用加载第三方组件js公共方法加载其他资源库// 加载聚合API// Ma…

Oracle数据库如何插入平方(²)立方(³)字符

第一步:创建数据表,字段一定要是NVARCHAR2类型的 第二步,插入数据用 unistr(1\00b3) 形式的写法 00b3 代表m,00b2代表㎡ SELECT * FROM TESTABC; UPDATE TESTABC set NAME1unistr(1\00b3); UPDATE TESTABC set NAME2unistr(2\00b2…

【LLM多模态】MiniGPT4模型结构和训练流程

note 图生文应用场景:比如电商领域根据产品图像生成产品描述、娱乐领域中根据电影海报生成电影介绍等MiniGPT-4将预训练的大语言模型和视觉编码器参数同时冻结,只需要单独训练线性投影层,使视觉特征和语言模型对齐。MiniGPT4的视觉编码器&am…

centos 8.5 Node v20.12.2 npm 安装及环境配置 配置淘宝最新镜像地址

1下载:Node.js — Download Node.js 2文件上传到服务器 rootlocalhost software]# tar xvf node-v20.12.2-linux-x64.tar.xz [rootlocalhost software]# mv node-v20.12.2-linux-x64/ /usr/local/node [rootlocalhost software]# vim /etc/profile export PA…

VSCode:设置搜索时的排除目录

VSCode搜索时默认会搜索目录下所有文件 $ tree . ├── a.c ├── m.c └── x └── b.c //a.c #include <stdio.h> #include <string.h>int main() {char s[] "hello\n";fprintf(stdout, s, strlen(s));return 0; } //m.c #include <stdio…

【LSTM】LSTM网络及参数学习笔记

图1 LSTM模型结构可视化 [6]. 图2 LSTM cell结构说明 图3 LSTM cell和num_units说明 [4]. 图4 LSTM的网络结构 1. LSTM 是对一个LSTM层的抽象&#xff0c;可以看成是由多个LSTM cell组成&#xff0c;是包含时间步的一个网络 2. LSTM cell 图2是LSTM在时间步上的结构&#xf…

【硬件开发】原型设计对于成功产品开发重要性及常见阶段

电子产品的设计与开发始于原型制作阶段。这些原型虽可能与最终产品极为相似&#xff0c;但总带有实验性质&#xff0c;因为电子原型的制作过程包括对新概念、新思想及新解决方案的测试。虽然存在出错的风险&#xff0c;跳过这一阶段可能会导致不必要的开支。不擅长电子硬件设计…

2024年想要开一家抖音小店,需要多少钱?一篇详解!

大家好&#xff0c;我是电商糖果 随着抖音卖货的持续火爆&#xff0c;抖音小店也成了电商行业讨论度最大的项目之一。 不少朋友都想知道&#xff0c;如果今年开抖音小店大概需要多少钱。 糖果做小店的时间也比较长&#xff0c;也经营了多家小店。 对于开一家抖音小店需要多…

多规格产品应该如何设置呢?

今天一用户从供应商手中拿到产品价目表&#xff0c;但是设置起来蒙圈了&#xff0c;接下来我们就一起设置一下吧&#xff5e; 一、产品价格表 我们通过供应商手中拿到产品价目表是这个样子的&#xff1a; 我们可以看到此产品的销售客价根据不同地区导致的价格不同&#xff0…

ABAP小技巧汇总(自用)

1.TIMESTAMP搜索帮助 PARAMETERS:p_begin TYPE ty_screen-date_begiu MATCHCODE OBJECT cpe_timestamp, "开始时间戳p_end TYPE ty_screen-date_end MATCHCODE OBJECT cpe_timestamp. "结束时间戳 效果&#xff1a;

Git笔记-常用指令

Git笔记-常用指令 一、概述二、仓库管理二、缓存区操作1. 添加文件到缓存区2. 取消缓存文件3. 忽略列表 三、日志状态信息四、分支操作五、六、 一、概述 这里记录一些git常用的指令。 二、仓库管理 # 本地仓库初始化 git init# 克隆仓库 git clone git_url # git clone ht…

win11个性化锁屏界面怎么关闭?

win11个性化锁屏界面关闭方法对于win11用户来说&#xff0c;关闭个性化锁屏界面是一个常见问题。本文将由php小编苹果详细介绍如何执行此操作&#xff0c;分步指导并提供操作截图。继续阅读以了解具体步骤。 win11个性化锁屏界面关闭方法 第一步&#xff0c;点击底部Windows图…

python数据分析常用基础语法

Python语言基础——语法基础 前言一、变量的介绍与使用变量的介绍变量命名规则变量的使用拓展 二、标识符标识符命名命名规则注意事项 三、数据类型数据类型的介绍数据类型的查看示例 四、输入与输出输入和输出的介绍format格式化输出占位符 五、代码缩进与注释代码缩进 前言 …