Git快速掌握,通俗易懂

news2025/1/18 7:23:28

Git分布式版本控制工具

介绍


Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git是由Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。Git可以帮助开发者们管理代码的版本,避免代码冲突,方便合并代码等。而在当下Git已经成为最重要的开发工具之一

什么是版本控制?

前面说了这么多,肯定会有博友会问,既然Git是一个版本控制工具,那版本控制又是什么呢?

版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。它可以帮助你管理项目中的文件、代码和数据,跟踪它们的变化,以及协同团队成员之间的工作。

举个例子,对于软件来说,我们所知的修图软件ps有2023版、2022版等不同版本,而代码编辑器vscode也有2021版、2019版等多个版本。这里所指的就是这些软件的版本。对于文件来说,版本控制也是非常重要的。无论是文档、图片还是代码文件,我们都可能需要创建不同版本的副本来追踪和管理变化。

举个例子,假设你正在编辑一份报告文档,你可能会经历多次修改和修订。每次修改后,你可以使用版本控制系统保存一个新的版本,以便随时回溯到之前的版本。这样,如果你发现某个修改有问题或者想要查看之前的更改,你可以轻松地找到并恢复到之前的版本。

另外,版本控制也可以用于团队协作。当多个人同时编辑同一个文件时,版本控制系统可以自动检测冲突并帮助解决。每个人所做的修改都会被视为不同的版本,系统会将它们合并在一起,确保最终的文件是完整且没有冲突的。

为什么要学习Git?

常见的版本控制工具有Git、Subversion(SVN)、Mercurial等,而Git因为其开源的特性已经是现在最流行的版本控制工具

Git不仅可以进行版本控制,还能将文件内容以及版本记录保存在远程服务器上。这样,无论你在哪里,只要有网络连接,就可以获取到你的项目文件,极大地提高了工作的便捷性。

虽然Git在存储空间上比SVN更占用空间,(因为Git在每个端都保留了所有的版本历史),但是其在流行程度、功能丰富方面却比SVN有优势。Git 相对于SVN不仅仅是个版本控制系统,它也是个内容管理系统,工作管理系统等。因此,学习Git无疑是一个值得的选择。

git工作原理 / 流程:

fetch/clone
checkout
push
checkout
add
commit
Remote
Repository
workspace
lndex

Workspace:工作区
Index / Stage:暂存区
Repository:仓库区(或本地仓库)
Remote:远程仓库

这个流程图描述了 Git 的常用命令之间的关系:

  • 开发人员可以使用 git clone 从远程仓库克隆项目到本地。
  • 他们可以使用 git push 将本地仓库的更改推送到远程仓库。
  • 他们可以使用 git add 将文件添加到暂存区。
  • 然后使用 git commit 将暂存区的更改提交到本地仓库。
  • 使用 git checkout 可以在分支之间切换,以及创建新的分支。

git pull 命令包含在 git clonegit checkout 中,因为它用于从远程仓库拉取最新更改到本地仓库。

1. Git安装配置


在使用Git之前,我们需要先安装GitGit目前支持在Linux/Unix、Solaris、Mac和Windows平台上运行。
Git的各平台安装包下载地址如下:https://git-scm.com/downloads
在这里插入图片描述
点击Windonws版本安装即可,完成安装之后,就可以使用命令行的 git 工具

在这里插入图片描述
我们点击右键这里会出现两个新的右键菜单,一个叫做Git GUI here,一个叫做Git Bash here

  • Git GUI here就是它自带的客户端工具
  • Git Bash here是一个命令行窗口

基本配置

点击Git Bash here在命令行窗口进行一下配置

1.设置用户信息

用户名:

git config --global user.name "注册名"

邮箱:

git config --global user.email "注册邮箱"

2.查看配置信息

查看全局配置信息:

git config --global --list

这将列出全局配置信息,包括用户名、邮箱等。
在这里插入图片描述

2. 远程仓库配置


远程仓库有很多,比如github,国内的码云,局域网自建git服务器,托管在其他地方的服务器,本文以github为例
网址https://github.com没有注册的可以先去注册一下

新建仓库: 点击右上角,加号,new repository
在这里插入图片描述

下一步
请添加图片描述

填写完成后 点击右下发创建存储库
在这里插入图片描述

如,我已经建立好的仓库
在这里插入图片描述

3. 生成(配置)SSH


git客户端安装后,如何和远程仓库,如github连接呢?我们使用SSH。

SSH是Secure Shell的缩写,它是一种用于安全远程登录到计算机系统并在网络上传输数据的协议。SSH通过加密的方式保护数据在网络上传输的安全性,因此它广泛应用于远程管理和文件传输

我们刚注册完账号后还没有配置SSH密钥,我们先生成一个SSH
在这里插入图片描述

检查是否已有SSH密钥对:

在终端(Linux和macOS)或命令提示符(Windows)中运行以下命令来检查是否已经存在SSH密钥对:

ls -al ~/.ssh

如果已经存在密钥对,则会显示在该目录下。

生成SSH(以有SSH可以跳过这一步)

ssh-keygen -t rsa -C "自己的邮箱"

生成成功,如下图所示:
SSH文件存放在C:/User/用户/.ssh

  • id_rsa: 这是你的SSH私钥文件。私钥文件用于身份验证,通常不应该泄露给其他人。

  • id_rsa.pub: 这是与私钥相关联的公钥文件。公钥文件可以与他人共享,以便他们将其添加到他们的服务器上,以允许你通过私钥进行身份验证

在这里插入图片描述

如果找不到C:/User/用户/.ssh

生成一个新的SSH密钥
打开 Git Bash,输入如下命令,然后连续按三个回车即可:

ssh-keygen -t rsa -C "你的邮箱"

然后会出来提示Enter file in which to save the key 后面是一个路径,你就会找到你想要的.ssh文件夹了,去电脑里找吧
在这里插入图片描述

github配置SSH

用记事本打开id_rsa.pub文件,全选,复制全文
在这里插入图片描述

打开github 点击右上角用户头像 点击设置 点击SSH密钥
请添加图片描述

点击New SSH key创建一个新SSH密钥
请添加图片描述

起一个标题,将之前复制的密钥粘贴上去
在这里插入图片描述

测试SSH连接,在控制台输入

ssh -T git@github.com

按照提示输入yes,回车,提示successfully之类的就说明SSH连接正常,github上的钥匙也会变成绿色
在这里插入图片描述

4. 推送文件到远程仓库


建立本地仓库

选择一个需要版本管理的项目文件夹,这里以我桌面的一个文件夹为例
在这里插入图片描述
打开文件夹右键 git bash中执行命令,将该文件夹初始化为一个仓库

git init

在这里插入图片描述
执行命令后文件夹内会出现一个隐藏的文件夹.git,没有的话,设置一下文件夹选项,显示隐藏文件
在这里插入图片描述

远程推送文件

基本流程:add->commit->push

  1. 添加并提交文件到本地仓库:
    使用 git add 命令将文件添加到暂存区,然后使用 git commit 命令将文件提交到本地仓库:

    git add <文件名>
    git commit -m "提交信息"
    
  2. 连接到远程仓库:
    如果还没有连接到远程仓库,你需要使用 git remote add 命令添加远程仓库地址:

    git remote add origin <远程仓库URL>
    

    其中 <远程仓库URL> 是你在GitHub上创建的仓库的地址。
    在这里插入图片描述

  3. 推送本地提交到远程仓库:
    一旦连接到了远程仓库,你可以使用 git push 命令将本地提交推送到远程仓库:

    git push origin <分支名>
    

    其中 <分支名> 是你要推送到的远程仓库的分支名称。

    如果想要首次推送到 master(主要分支),加上 -u 参数会将本地分支与远程分支关联起来。

    git push -u origin master
    

在这里插入图片描述
提交成功
在这里插入图片描述

常用的Git命令及其用法


  1. git init:初始化一个新的Git仓库。

    git init
    
  2. git clone:克隆现有仓库到本地。

    git clone <仓库URL>
    
  3. git add:将文件添加到暂存区。

    git add <文件名>
    
  4. git commit:将暂存区中的文件提交到本地仓库。

    git commit -m "提交信息"
    
  5. git status:查看当前工作区和暂存区的状态。

    git status
    
  6. git log:查看提交历史记录。

    git log
    
  7. git branch:列出本地分支,或者创建新分支。

    git branch <分支名>
    
  8. git checkout:切换分支。

    git checkout <分支名>
    
  9. git merge:合并指定分支到当前分支。

    git merge <要合并的分支>
    
  10. git pull:拉取远程仓库的变化并合并到本地。

    git pull origin <分支名>
    
  11. git push:推送本地变化到远程仓库。

    git push origin <分支名>
    
  12. git remote -v:查看远程仓库的信息。

    git remote -v
    
  13. git remote add:添加一个新的远程仓库。

    git remote add <远程仓库名> <仓库URL>
    
  14. git remote remove:移除指定的远程仓库。

    git remote remove <远程仓库名>
    
  15. git diff:查看工作区与暂存区的差异。

    git diff
    

这些是Git中一些常见的命令,但Git还提供了许多其他功能强大的命令,可以根据实际需要查阅Git官方文档或者通过 git --help 查看帮助信息。

结语


Git是一个强大的版本控制系统,通过掌握上述基本概念和常用命令,你可以更好地管理和协作项目代码。除了本文介绍的内容,Git还有许多高级功能和技巧,可以根据实际需求进行学习和探索。希望本文能够帮助你快速入门Git,并在日常开发中得到应用。

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

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

相关文章

RabbitMQ配置消息转换器

1. 默认转换器 Test public void testSendMap() throws InterruptedException {// 准备消息Map<String, Object> msg new HashMap<>();msg.put("name", "harry");msg.put("age", 21);// 发送消息rabbitTemplate.convertAndSend(&q…

FreeRTOS知识点

1>任务调度算法 1.抢占式调度&#xff1a;高优先级的任务优先执行&#xff0c;并且可以打断低优先级的任务执行。 在FreeRTOSConfig.h中开启configUSE_PREEMPTION宏&#xff0c;将宏设置为1&#xff0c;关闭&#xff08;将宏设置为0&#xff09; 2.时间片轮转&#xff1a…

什么是 Flet?

什么是 Flet&#xff1f; Flet 是一个框架&#xff0c;允许使用您喜欢的语言构建交互式多用户 Web、桌面和移动应用程序&#xff0c;而无需前端开发经验。 您可以使用基于 Google 的 Flutter 的 Flet 控件为程序构建 UI。Flet 不只是“包装”Flutter 小部件&#xff0c;而是…

Repo命令使用实例(三十八)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

动态多目标优化算法基准测试问题JY

论文题目&#xff1a;Evolutionary Dynamic Multiobjective Optimization: Benchmarks and Algorithm Comparisons 进化动态多目标优化&#xff1a;基准测试和算法比较&#xff08;Shouyong Jiang and Shengxiang Yang, Senior Member, IEEE&#xff09;IEEE TRANSACTIONS ON …

【UE4】 通过按钮点击实现摄像机的切换 并通过鼠标控制新摄像机的旋转

效果 步骤 首先创建了4个Actor蓝图类 每个蓝图类内只拥有一个摄像机组件 将每个actor蓝图类摆放到场景的合适位置 在关卡蓝图中创建自定义事件&#xff0c;当该事件触发时切换摄像机 创建一个控件蓝图&#xff0c;在控件蓝图中创建如下5个按钮&#xff0c;并创建点击事件。按钮…

基于HTML5实现动态烟花秀效果(含音效和文字)实战

目录 前言 一、烟花秀效果功能分解 1、功能分解 2、界面分解 二、HTML功能实现 1、html界面设计 2、背景音乐和燃放触发 3、燃放控制 4、对联展示 5、脚本引用即文本展示 三、脚本调用及实现 1、烟花燃放 2、燃放响应 3、烟花canvas创建 4、燃放声音控制 5、实际…

SpringIOC之support模块ResourceBundleMessageSource

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

垃圾分类|城市垃圾分类管理系统|基于Springboot的城市垃圾分类管理系统设计与实现(源码+数据库+文档)

城市垃圾分类管理系统目录 目录 基于Springboot的城市垃圾分类管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、垃圾列表 2、公告信息管理 3、公告类型管理 四、数据库设计 1、实体ER图 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 …

php基础学习之运算符(重点在连接符和错误抑制符)

运算符总结 在各种编程语言中&#xff0c;常用的运算符号有这三大类&#xff1a; 算术运算符&#xff1a;&#xff0c;-&#xff0c;*&#xff0c;/&#xff0c;%位运算符&#xff1a;&&#xff0c;|&#xff0c;^&#xff0c;<<&#xff0c;>>赋值运算符&…

【深入理解DETR】DETR的原理与算法实现

1 DETR算法概述 ①端到端 ②Transformer-model 之前的方法都需要进行NMS操作去掉冗余的bounding box或者手工设计anchor&#xff0c; 这就需要了解先验知识&#xff0c;增加从超参数anchor的数量&#xff0c; 1.1 训练测试框架 一次从图像中预测n个object的类别 训练阶段我们…

数据结构——顺序表专题

目录 1. 数据结构的相关概念什么是数据结构为什么需要数据结构&#xff1f; 2. 顺序表顺序表的概念及结构顺序表分类静态顺序表动态顺序表 3. 动态顺序表的实现准备工作顺序表的初始化顺序表的扩容尾插头插尾删头删指定位置插入数据指定位置删除数据 4. 全部完整代码**test.c**…

构建智慧交通平台:架构设计与实现

随着城市交通的不断发展和智能化技术的迅速进步&#xff0c;智慧交通平台作为提升城市交通管理效率和水平的重要手段备受关注。本文将探讨如何设计和实现智慧交通平台的系统架构&#xff0c;以应对日益增长的城市交通需求&#xff0c;并提高交通管理的智能化水平。 ### 1. 智慧…

中小学信息学奥赛CSP-J认证 CCF非专业级别软件能力认证-入门组初赛模拟题第二套(阅读程序题)

CSP-J入门组初赛模拟题二 二、阅读程序题 (程序输入不超过数组或字符串定义的范围&#xff0c;判断题正确填√错误填X;除特殊说明外&#xff0c;判断题 1.5分&#xff0c;选择题3分&#xff0c;共计40分) 第一题 1 #include<bits/stdc.h> 2 using namespace std; 3 i…

算法——数论——快速幂

目录 快速幂 费马小定理 一、试题 算法训练 A的B的C次方次方 快速幂 快速幂是一种用于快速计算幂运算的算法。计算复杂度 O(log n)基本思想是利用指数 n 的二进制展开形式&#xff0c;将 转化为多个 a 的幂的乘积&#xff0c;然后通过迭代快速计算。 快速幂的示例代码&…

鸿蒙开发系列教程(二十一)--轮播处理

轮播处理 Swiper本身是一个容器组件&#xff0c;当设置了多个子组件后&#xff0c;可以对这些子组件进行轮播显示 在自身尺寸属性未被设置时&#xff0c;会自动根据子组件的大小设置自身的尺寸 参数&#xff1a; 通过loop属性控制是否循环播放&#xff0c;该属性默认值为tr…

[GXYCTF2019]禁止套娃

进来发现只有这句话&#xff0c;习惯性访问一下flag.php&#xff0c;发现不是404&#xff0c;那就证明flag就在这了&#xff0c;接下来要想办法拿到flag.php的源码。 这道题是.git文件泄露网页源码&#xff0c;githack拿到index.php源码 这里观察到多次判断&#xff0c;首先要…

【C/C++语法基础】2.输入与输出(✨新手推荐阅读)

前言 在C中&#xff0c;输入与输出是程序与用户进行交互的基本方式。C提供了多种方式进行数据的输入与输出&#xff0c;其中最常用的是printf、scanf、cin和cout。此外&#xff0c;我们还会讨论如何取消cin和cout的同步流&#xff0c;以及了解各种转义字符的用法。 1.printf函…

算法学习——LeetCode力扣回溯篇3

算法学习——LeetCode力扣回溯篇3 491. 非递减子序列 491. 非递减子序列 - 力扣&#xff08;LeetCode&#xff09; 描述 给你一个整数数组 nums &#xff0c;找出并返回所有该数组中不同的递增子序列&#xff0c;递增子序列中 至少有两个元素 。你可以按 任意顺序 返回答案。…

第23讲 微信用户管理实现

package com.java1234.entity;import com.baomidou.mybatisplus.annotation.TableName; import com.fasterxml.jackson.databind.annotation.JsonSerialize; import lombok.Data;import java.io.Serializable; import java.util.Date;/*** 微信用户信息实体* author java1234_小…