【基础篇】Git 基础命令与核心概念

✅作者简介:大家好,我是小杨
📃个人主页:「小杨」的csdn博客

🐳希望大家多多支持🥰一起进步呀!


一,Git 初识

1.1,问题引入

不知道你工作或学习时,有没有遇到这样的情况:我们在编写各种文档时,为了防止出现文档丢失或者更改失误的情况,失误后也能恢复到原来的版本,不得不复制出一个副本,比如:

“文档报告-v1”

“文档报告-v2”

“文档报告-v3”

每个版本都有各自的内容,但最终只会有一份文档报告被我们使用。

但在此之前的工作都需要这些不同版本的文档报告,于是每次都要经过复制粘贴操作得到副本,产出的文件就会越来越多,虽然文件多不是什么大问题,但问题是:随着版本数量的不断增多,你是否还记得这些版本各自都是修改了什么吗?

这个文档报告是如此,我们写的项目代码也是如此,就是也存在上述这个问题的。那如何解决上述问题呢?


1.2,问题解决

那如何解决上述问题呢?这就便有了版本控制器。

何为版本控制器?所谓的版本控制器,就是能让你了解到一个文件的历史,以及它的发展过程的系统。

通俗的讲就是一个可以记录工程的每一次改动和版本迭代的一个管理系统,同时也方便多人协同作业。

目前最主流的版本控制器就是Git 。Git可以控制电脑上所有格式的文件,例如doc、 excel、dwg、dgn、rvt等等。对于我们开发人员来说,Git最重要的就是可以帮助我们管理软件开发项目中的源代码文件!

注意事项:

1,Git只能跟踪文本文件的改动,比如TXT文件,网页,所有的程序代码等等。版本控制系统可以告诉你每次的改动,比如在第5行添加了一个单词”Linux",或者在第8行删了一个单词"Windows"。

2,而对于图片、视频这些二进制文件,虽然也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来。也就是只能知道图片从10OKB改成了120KB,但到底改了啥,版本控制系统不知道,也没法知道。


1.3,Git 的功能

Git 是目前最主流的版本控制器,其主要实现以下的功能:

  1. 版本控制和分支管理
  2. 本地与远程仓库操作:提交,拉取,合并,推送
  3. 团队协同开发:团队中的成员可通过克隆仓库到本地后进行独立开发

1.4,Git 的工作机制

在谈到Git的工作机制之前,首先了解几个基本概念:

  1. 工作区:在电脑上所能看到或者写代码文件的目录。
  2. 暂存区:临时存储工作区的代码,一般存放在.git目录下的index文件中,也被称为索引。
  3. 版本库:工作区有一个隐藏目录 .git,这个不算工作区,而是 Git 的版本库。其里面的所有文件都可被Git 管理和控制。
  4. objects:Git 的对象库,位于 .git/objects 目录下,修改的工作区内容会写入对象库的一个新的object对象中。

下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:

在这里插入图片描述

Git 的工作机制如下:

1,工作区的代码文件通过使用git add命令将其放到暂存区
2,暂存区的代码文件通过使用git commit命令将其提交到版本库
3,版本库的代码文件通过使用git push命令将其推送到远程仓库中


二,Git 使用

2.1,Centos 安装 Git

1. Git 查看命令:

git

2. Git 下载命令:

sudo yum -y install git

3. Git 版本查看命令:

git --version

4. Git 卸载命令:

sudo yum -y remove git 

2.2,Ubuntu 安装 Git

1. Git查看命令:

git

2. Git 下载命令:

sudo apt-get -y install git

3. Git 版本查看命令:

git --version

4. Git 删除命令:

sudo apt-get -y remove git

2.3,本地仓库创建

1. 创建一个文件夹并进入

mkdir gitcode

2. Git 本地仓库创建命令:

git init

3. Git本地仓库具体目录查看命令:

tree .git

4. 代码实操:

image-20240417212036088

在这里使用tree .git命令进行查看Git本地仓库具体目录时,会出现上述报错信息。出现其报错原因是在centos中,tree命令不存在,需要通过sudo yum -y install tree 命令下载tree,操作如下:

image-20240417212631162

下载完成后通过使用tree .git命令就可以查看Git本地仓库具体目录了。

image-20240417212840976

5. 本地仓库创建注意

仓库是进行版本控制的一个文件目录,所以要想对文件进行版本控制,就必须先创建一个仓库出来,然后在创建的文件目录下使用git init指令执行创建一个Git本地仓库的操作。


2.4,本地仓库配置

当安装Git后首先要做的事情是设置你的用户名称e-mail地址,这是非常重要的。

  1. 特定配置添加命令:
git config [-global] user.name "Your Name"
git config [-global] user.email "email@example.com"# 把 Your Name 改成你的昵称
# 把 email@example.com 改成邮箱的格式,只要格式正确即可。
  1. 所有配置查看命令:
git config -l
  1. 特定配置删除命令:
git config [--global] --unset user.name
git config [--global] --unset user.email
  1. 代码实操:

image-20240417214247412

5. 本地仓库配置注意

–global选项是一个可选项。如果使用了该选项,表示这台机器上所有的git仓库都会使用这个配置。如果你希望在不同仓库中使用不同的name或e-mail,可以不使用–global选项,但要注意的是,执行命令时必须要在仓库里,并且如果特定配置添加时使用了–global选项,删除特定配置时也需要使用该选项。


2.5,本地文件操作

1.本地文件准备:

touch file

2.本地文件添加命令:

git add [file1] [file2] ...  # 添加⼀个或多个⽂件到暂存区
git add [dir]                # 添加指定⽬录到暂存区,包括⼦⽬录
git add .                    # 添加当前⽬录下的所有⽂件改动到暂存区

3.本地文件提交命令:

 git commit -m "message"                       # 提交暂存区全部内容到仓库中git commit [file1] [file2] ... -m "message"   # 提交暂存区的指定⽂件到仓库区git commit [dir] ... -m "message"	           # 提交暂存区的指定目录到仓库区

4.本地文件提交记录查看命令:

git log [--pretty=oneline]

5.代码实操:

image-20240417222545411

6.本地仓库状态查看命令:

git status

7.文件差异查看命令:

git diff [file]              # 暂存区和工作区文件差异查看命令
git diff HEAD -- [file]      # 版本库和工作区文件差异查看命令

8.代码实操:

image-20240417225733879


2.6,本地仓库结构目录

通过使用tree .git 命令就可以查看本地仓库的结构目录,下图所示:

image-20240417231144776

在本地仓库的结构目录中,需要特别关注下面几个:

• index:暂存区,git add后会更新该内容。

• HEAD:默认指向 master 分支的一个指针。

• refs/heads/master:文件里保存当前 master 分支的最新commit id 。

• objects: 包含了创建的各种版本库对象及内容,可以简单理解为放了 git 维护的所有修改。

代码实操:

image-20240417234308038

注意1:查找object时要将commit id分成2部分,其前2位是文件夹名称,后38位是文件名称。找到这个文件之后,一般不能直接看到里面是什么,该类文件是经过sha(安全哈希算法)加密过的文件,我们可以使用 git cat-file 命令来查看版本库对象的内容。

注意2:通过使用git cat-file命令来查看版本库对象的内容,发现内容中有tree和parent。其中tree表示当前提交的文件状态快照,它包含了文件和子目录的信息,而parent表示当前提交对象的父提交,也就是它的前一个历史状态。


2.7,文件版本回退

git reset命令用于回退版本,可以指定退回某一次提交的版本。

git reset命令语法格式为:git reset [–soft | --mixed | --hard] [HEAD]

–soft:对于工作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。

–mixed:默认参数,将暂存区和版本库的内容回退到指定版本,工作区文件不变。

–hard:将版本库,暂存区,工作区都回退到指定版本,使用该参数需要慎重考虑。

HEAD:表示回退的版本,有三种写法,分别为:直接使用commit id,HEAD(当前版本),HEAD^(上一版本),HEAD0(当前版本),HEAD1(上一版本)。


2.8,文件撤销修改

文件撤销修改有3种情况以及对应的解决方法:

  1. 工作区内容未添加和提交:直接修改工作区内容【不推荐,容易操作失误】,使用git checkout -- [file]命令撤销修改【推荐】。
  2. 工作区内容添加但未提交:使用git reset --mixed HEAD [file]命令将暂存区内容回退到当前版本,接着进行上述第一种情况操作。
  3. 工作区内容添加并已提交:使用git reset --hard HEAD^ [file]命令将版本库,暂存区,工作区内容回退到上一版本。

2.9,文件删除

文件删除不仅需要将工作区文件删除,还需要将版本库中的文件删除。有2种方式:

  1. 首先需要使用git rm [file]命令删除工作区和暂存区的文件,然后通过git commit命令进行删除版本库中的文件。
  2. 首先需要使用rm [file]命令删除工作区文件,然后通过git addgit commit命令依次进行删除暂存区和版本库中的文件。

三,分支管理

3.1,分支管理理解

Git分支管理是一种组织和管理代码变更的方法,它允许团队在同一个代码库中同时进行多个独立的工作。通过使用分支,团队可以在不影响主要代码流的情况下开发新功能、修复bug、测试变更等。

  1. 主分支(Main/Branch):主分支是项目的主要分支,通常用于发布稳定版本。在过去,主分支通常被称为“master”,但随着对语言的更新,更倾向于使用“main”。
  2. 开发分支(Develop Branch):开发分支是用于整合和测试新功能的分支。团队成员通常从主分支创建开发分支,并在此处进行开发工作。当开发完成并且测试通过时,开发分支通常会被合并回主分支。
  3. 功能分支(Feature Branch):功能分支用于开发单个功能或修复单个问题。每个功能或问题通常对应一个独立的功能分支。功能分支通常从开发分支创建,并在完成后被合并回开发分支。
  4. 发布分支(Release Branch):发布分支用于准备发布新版本。在发布分支上进行最后的测试、修复bug和准备版本号等工作。完成后,发布分支会被合并回主分支,并且通常会被打上标签以标记发布版本。
  5. 修复分支(Hotfix Branch):修复分支用于紧急修复生产环境中的bug。它们通常是从主分支分支出来的,并且在修复后会合并回主分支和开发分支。

3.2,分支管理操作

1.分支查看

git branch            # 列出所有本地分支,当前分支会用星号标记。
git branch -a         # 列出所有本地和远程分支。

2.分支创建

git branch <branch-name> 

3.分支切换

git checkout <branch-name> 

4.分支合并

git merge <branch-name>           # 将指定分支合并到当前分支。
git merge --no-ff <branch_name>   # 以非快进模式合并分支,保留合并历史。

5.分支删除

git branch -d <branch-name>
git branch -d <branch_name>       # 删除指定的本地分支,如果分支未合并,则会报错。
git branch -D <branch_name>       # 强制删除指定的本地分支,即使分支未合并也会删除。

6.分支创建并切换

git branch -b <branch-name> 

7.分支重命名

git branch -m <old_branch_name> <new_branch_name

8.合并基点查看

git merge-base <branch1> <branch2>   # 查看两个分支的最近共同祖先,通常用于解决合并冲突。

9.分支历史查看

git log --oneline --graph --all      # 以图形化方式查看所有分支的提交历史。

10.远程分支跟踪

git branch -u <remote>/<branch>      # 将当前分支设置为追踪指定的远程分支。

11.分支推送

git push <remote> <branch_name>      # 将本地分支推送到远程仓库。
git push -u <remote> <branch_name>   # 第一次推送分支时,使用 -u 参数建立追踪关系。

12.远程分支拉取

git fetch <remote>                   # 从远程仓库拉取所有分支的更新。
git fetch <remote> <branch_name>     # 从远程仓库拉取指定分支的更新。

13.默认分支设置

git config --global init.defaultBranch <branch_name>   #设置新建仓库时的默认分支。

3.3,分支管理注意

1,分支合并策略有两种,分别为:fast forwardnon-fast forward

fast forward :在合并分支时,Git 可以简单地将目标分支指针向前移动到要合并的分支的最新提交,而不需要创建新的合并提交。这种方式的合并操作不会产生额外的合并提交,因此合并历史非常干净,分支图也非常线性清晰。

non-fast forward:在合并分支时,Git 需要创建一个新的合并提交,将两个分支的更改集成在一起。这种方式的合并操作会在提交历史中创建一个新的合并节点,显示两个分支的合并点。

image-20240418182306193

2,分支合并冲突问题

场景1:master分支和dev分支各自都分别有新的提交,在这种情况下,Git试图把各自的修改合并起来,但这种合并就可能会有冲突。

当Git合并分支时,如果发现有冲突,它会在文件中标记出这些冲突,这种标记使用<<<<<<<=======,和>>>>>>>来区分不同分支的内容。

这时,你需要手动解决这个冲突,编辑文件,然后提交解决后的结果。这样做可以确保冲突得到正确解决,并且合并结果被正确保存。

image-20240418222849741

场景2:现有主分支master运行代码程序,修复分支fix修复bug,开发分支dev2开发功能,fix分支和dev2分支都有新的提交,在这种情况下,Git试图把各自的修改合并起来,会出现合并冲突。

当将修复分支(fix)合并到主分支(master)后,接着再把功能分支(dev2)合并至主分支,可能引入了一些与正在开发的功能(在dev2分支上)不兼容的更改,从而导致主分支的代码出现错误。

image-20240418230808530

解决这个问题的方法就是:在dev2分支上合并master,再让master去合并dev2,这样做的目的是有冲突可以在dev2分支上解决并进行测试,而不影响master主分支。

image-20240418230609198


四,远程操作

4.1,远程仓库克隆

1,使用HTTPS方式克隆

git clone https:....

2,使用SSH方式克隆

git clone ssh:....

注:在使用SSH方式克隆仓库时,需要添加公钥至远程仓库中,如果未进行添加,服务器会拒绝我们的clone操作。设置方式:

  1. 查看服务器主目录中有没有.ssh目录

  2. 再看.ssh目录中有没有id_rsa(私钥)id_rsa.pub(公钥)这两个文件

  3. 如果没有上述两个文件,则需要创建SSH KEY

    ssh-keygen -t rsa -C "邮箱"     # 邮箱要与Gitee上的保持一致
    
  4. 使用cat命令查看id_rsa.pub(公钥)这个文件,然后将出现的一串公钥复制

  5. 把复制的公钥粘贴至Gitee的添加公钥页面,确认即可


4.2,远程仓库推送

远程仓库克隆到本地仓库之后,需要配置本地仓库的user.name和user.email。操作命令如下:

git config [user.name/user.email] [值]

这里的用户名和邮箱也要和Gitee上的保持一致。

git push [远程仓库名] [本地分支]:[远程分支]

如果本地分支和远程分支相同,可以省略:[远程分支]


4.3,远程仓库拉取

在日常开发工作中,需要从远处仓库中拉取最新的代码,操作命令如下:

git pull [远程仓库名] [远程分支]:[本地分支]

五,标签管理

在Git中,标签(tag)是用于标记特定提交的版本号或者别名。标签可以帮助你在代码库中标记重要的里程碑、版本发布等信息。

5.1,创建标签

1,轻量级标签(Lightweight Tags):只是一个指向特定提交的引用

git tag <tag_name>

2,带注释的标签(Annotated Tags):包含更多关于该标签的信息,如标签作者,发布日期,发布说明等

git tag -a <tag_name> -m "tag message"

5.2,查看标签

1,查看所有标签:

git tag

2,查看特定标签的详细信息:

git show <tag_name>

5.3,删除标签

git tag -d <tag_name>

5.4,推送标签到远程仓库

1,推送单个标签:

git push origin <tag_name>

2,推送所有标签:

git push origin --tags

5.5,删除远程仓库上的标签

git push origin --delete <tag_name>

结语

这就是本期博客的全部内容啦!如果有什么其他的问题无法自己解决,可以在评论区留言哦!

最后,如果你觉得这篇文章写的还不错的话或者有所收获的话,麻烦小伙伴们动动你们的小手,给个三连呗(点
赞👍,评论✍,收藏📖),多多支持一下!各位的支持是我最大的动力,后期不断更新优质的内容来帮助大家,一起进步。那我们下期见!


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

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

相关文章

Flutter 从 Assets 中读取 JSON 文件:指南 [2024]

在本教程中&#xff0c;我们将探讨如何从 Flutter 项目中的 asset 中读取 JSON 文件。您将找到详细的解释、实际示例和最佳实践&#xff0c;使您的 JSON 文件处理顺利高效。那么&#xff0c;让我们深入了解 Flutter 和 JSON 的世界吧&#xff01; 从 asset 中读取 JSON 文件 …

与 Apollo 共创生态:Apollo 七周年大会给带来的震撼

文章目录 一、七年蛰伏&#xff0c;Apollo 迎来“智变”时刻二、Apollo 企业生态计划与开放平台2.1 Apollo X 企业自动驾驶解决方案2.2 Apollo 开放平台携手伙伴共创生态 三、个人感悟 一、七年蛰伏&#xff0c;Apollo 迎来“智变”时刻 让我们把时间倒回到 2013 年&#xff0…

微服务之分布式理论概述

一、分布式技术相关的理论 CAP理论 CAP定理(CAP theorem)&#xff0c;⼜被称作布鲁尔定理(Eric Brewer)&#xff0c;1998年第⼀次提出. 最初提出是指分布式数据存储不可能同时提供以下三种保证中的两种以上: (1) ⼀致性(Consistency): 每次读取收到的信息都是最新的; (2) …

玩转手机在AidLux上安装宝塔面板

AidLux&#xff0c;手机不用刷机、不用root&#xff0c;直接在手机应用市场就能下载使用。 1.4G的应用包&#xff0c;看起来挺大的&#xff0c;那是因为内嵌了一套完整的AIoT应用开发和部署平台。 不仅Android手机可以玩&#xff0c;华为的Harmony系统也可以使用。 使用它最主…

【声网】实现web端与uniapp微信小程序端音视频互动

实现web端与uniapp微信小程序端音视频互动 利用声网实现音视频互动 开通声网服务 注册声网账号 进入Console 成功登录控制台后&#xff0c;按照以下步骤创建一个声网项目&#xff1a; 展开控制台左上角下拉框&#xff0c;点击创建项目按钮。 在弹出的对话框内&#xff0c;依…

python版的openCV使用及下载

一、下载OpenCV模块 截止目前&#xff1a;现在OpenCV使用环境还是python3.8的版本所以咱们下载时记得用3.8版本的 终端下载&#xff1a;pip install -i https://pypi.tuna.tsinghua.edu.cn/simple opencv-python 这是国内的镜像下载能快一些&#xff1b; 下载成功的标志&am…

Linux简单命令

目录 显示目录下的内容 ls 切换工作目录 cd 查看-当前工作目录pwd 创建-文件夹 mkdir 创建-文件 touch 查看-文件内容 cat 查看-分屏查看文件内容 more 删除-文件、文件夹 rm 复制-文件、文件夹 cp 移动-文件、文件夹 mv 查找-命令的程序文件存放处 which 查找-按文…

Linux平台Unity下RTMP|RTSP低延迟播放器技术实现

技术背景 国产操作系统对于确保信息安全、促进技术创新、满足特定需求以及推动经济发展等方面都具有重要意义&#xff0c;多以Linux为基础二次开发。2014年4月8日起&#xff0c;美国微软公司停止了对Windows XP SP3操作系统提供支持&#xff0c;这引起了社会和广大用户的广泛关…

SCI一区级 | Matlab实现BES-CNN-GRU-Mutilhead-Attention多变量时间序列预测

SCI一区级 | Matlab实现BES-CNN-GRU-Mutilhead-Attention秃鹰算法优化卷积门控循环单元融合多头注意力机制多变量时间序列预测 目录 SCI一区级 | Matlab实现BES-CNN-GRU-Mutilhead-Attention秃鹰算法优化卷积门控循环单元融合多头注意力机制多变量时间序列预测预测效果基本介绍…

Unreal Engine创建Plugin

打开UE工程&#xff0c;点击编辑&#xff0c;选择插件 点击“新插件”按钮&#xff0c;选择“空白选项”填入插件名字"MultiPlayerPlugin"&#xff0c;填入插件作者、描述&#xff0c;点击“创建插件”按钮打开C工程&#xff0c;即可看到插件目录&#xff0c;编译C工…

Linux网络编程---多进/线程并发服务器

一、多进程并发服务器 实现一个服务器可以连接多个客户端&#xff0c;每当accept函数等待到客户端进行连接时 就创建一个子进程 思路分析&#xff1a; 核心思路&#xff1a;让accept循环阻塞等待客户端&#xff0c;每当有客户端连接时就fork子进程&#xff0c;让子进程去和客户…

2分钟自己写小游戏:使用js和css编写石头剪刀布小游戏、扫雷小游戏、五子棋小游戏。新手老手毕业论文都能用。

系列文章目录 【复制就能用1】2分钟玩转轮播图,unslider的详细用法 【复制就能用2】css实现转动的大风车&#xff0c;效果很不错。 【复制就能用3】2分钟自己写小游戏&#xff1a;剪刀石头布小游戏、扫雷游戏、五子棋小游戏 【复制就能用4】2024最新智慧医疗智慧医院大数据…

MySQL:ACCESS DENIED FOR USER‘ROOT‘@‘IP地址

起因是使用若依的环境连接数据库时报错&#xff1a;远程数据库连接异常&#xff0c;最终原因是密码错误&#xff0c;且看分解 07:12:06.895 [main] INFO c.r.RuoYiApplication - [logStartupProfileInfo,686] - The following 1 profile is active: "druid" 07:12:…

阿里巴巴瓴羊基于 Flink 实时计算的优化和实践

摘要&#xff1a;本⽂整理⾃阿里云智能集团技术专家王柳焮⽼师在 Flink Forward Asia 2023 中平台建设专场的分享。内容主要为以下四部分&#xff1a; 阿里巴巴瓴羊基于 Flink 实时计算的平台演进Flink 能力优化与建设基于 Flink 的最佳实践未来规划 1. 阿里巴巴瓴羊基于 Flink…

等保测评有那些流程?为什么要做等保

根据《网络安全法》规定&#xff0c;网络运营者应当按照国家的网络安全技术标准和要求&#xff0c;采取技术措施保障网络安全&#xff0c;避免网络安全事件的发生。而等保测评是国家对企事业单位进行信息系统安全等级评定的一项重要制度&#xff0c;通过等级测评&#xff0c;可…

macOS 一些系统图标的存放位置 icns

macOS 一些系统图标的存放位置 icns macOS 中有很多好看的图标&#xff0c;有时候就想用一下它&#xff0c;我来告诉你他们的具体位置。 系统图标位置&#xff0c;像各种通用文件类型的图标都在这里面&#xff0c;里面好多高清的系统图标 /System/Library/CoreServices/Core…

Android Studio的button点击事件

xml添加onClick调用方法 public class MainActivity extends AppCompatActivity {// 创建系统时间的文本控件TextView systemTimeTextView;Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activit…

精酿啤酒:酿造工艺的自动化与智能化发展

随着科技的不断进步&#xff0c;自动化与智能化已成为啤酒酿造工艺的重要发展方向。Fendi Club啤酒紧跟时代潮流&#xff0c;积极推动酿造工艺的自动化与智能化发展&#xff0c;旨在提高生产效率、确保产品品质和满足市场需求。 Fendi Club啤酒引入自动化生产设备。他们采用自动…

外观模式【结构型模式C++】

1.概述 外观模式是一种结构型设计模式&#xff0c; 能为程序库、 框架或其他复杂类提供一个简单的接口。 2.结构   外观角色&#xff08;Facade&#xff09;&#xff1a;为多个子系统对外提供一个共同的接口&#xff0c;知道哪些子系统负责处理请求&#xff0c;将客户端的请…

Qt下使用OpenCV截取图像并在QtableWidget表格上显示

文章目录 前言一、在QLabel上显示图片并绘制矩形框二、保存矩形框数据为CSV文件三、保存截取图像四、将截取图像填充到表格五、图形视图框架显示图像六、示例完整代码总结 前言 本文主要讲述了在Qt下使用OpenCV截取绘制的矩形框图像&#xff0c;并将矩形框数据保存为CSV文件&a…