Git 基本原理和常用操作

这篇具有很好参考价值的文章主要介绍了Git 基本原理和常用操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Git

Git 是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。由 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开源的版本控制软件。

Git 常用操作

git 提交流程:工作区 -> git add 到暂存区 -> git commit 到本地版本库 -> git push 到远程库

远程库:局域网有 Gitlab;互联网有 GitHub、Gitee

Git 基本原理和常用操作,git
Git中最重要的就是提交记录,其他如标签分支HEAD 都对提交记录的“指针”引用,指向这些提交记录。

  • 提交记录之间也存在“指针”引用,每个提交会指向其上一个提交。
  • 标签 就是对某一个提交记录的的 固定 “指针”引用,取一个别名更容易记忆一些关键节点。存储在工作区根目录下.git\refs\tags
  • 分支 也是指向某一个提交记录的“指针”引用,“指针”位置可变,如提交、更新、回滚。存储在工作区根目录下.git\refs\heads
  • HEAD:指向当前工作分支/活动分支(最新提交)的一个“指针”引用,存在在“.git/HEAD”文件中,存储的内容为“ref: refs/heads/master”。相当于在一个 commit 链表上的指针,链表上的每个节点都是一次 commit。

checkout

分支切换,使用 git checkout dev切换分支时,干了两件事:

  • ①、HEAD指向dev:修改HEAD的“指针”引用,指向dev分支。
  • ②、还原工作空间:把dev分支内容还原到工作空间。

切换时还没提交的代码怎么办?

  • 如果修改(包括未暂存、已暂存)和待切换的分支没有冲突,则切换成果,且未提交修改会一起带过去,所以要注意!
  • 如果有冲突,则会报错,提示先提交或隐藏,关于隐藏可查看后续章节内容“stash”。

checkout 也可用于撤销,只针对未提交的修改。

commit --amend

如果我们提交修改后发现有些文件没有添加,或者提交信息写错了,则可以通过 --amend 选项修正提交。

reset

重置版本,原理是通过移动 HEAD 指针,所以支持回退版本和重新恢复回退前的版本,可以实现版本之间的来回穿梭。

三种模式

  • soft,工作区、暂存区状态不变
  • mixed,默认模式,工作区不变,撤销暂存区状态
  • hard,强制回退,撤销工作区和暂存区状态!

注意,hard 模式 操作会丢失reset之前的未提交的代码!(也可以恢复但是比较麻烦)

revert

撤销提交,安全撤销某一个提交记录,基本原理就是创建一个新的提交,用原提交的逆向操作来完成撤销操作。注意,这不同于resetreset是回退版本,revert只是用于撤销某一次历史提交,操作是比较安全的。

merge

合并分支,把两个分支的修改内容合并到一起,git merge [branch],将分支[branch]合并到当前分支。根据要合并的内容的不同,具体合并过程就会有多种情况。

rebase

衍合分支,变基,把两个分支的修改内容合并到一起的办法有两种:mergerebase,作用都是一样的,区别是rebase的提交历史更简洁,干掉了提交分叉,但 merge 的提交历史更完整,更可追溯。

rebase 是一个相当强大的命令,rebase可以加上-i进行交互式地变基,我们可以在任何想要的修改完成之后停止,也可以添加文件或者是做其他想要做的事情。

rebase 命令推荐文章:

git rebase详解(图解+最简单示例,一次就懂)_风中一匹狼v的博客-CSDN博客

详解git rebase,让你走上git大神之路 - 知乎 (zhihu.com)

Git提交错了不用慌,这三招帮你修改记录 - 知乎 (zhihu.com)

git rebase的时候捅娄子了,怎么办?在线等…… - 知乎 (zhihu.com)

stash

隐藏操作,如果切换分支时,未提交修改的内容没有冲突,是可以成功切换的,未提交修改会被带过去。

但是如果有未提交修改,切换分支时报错,那么就可以把当前工作区、暂存区 未提交的内容“隐藏”起来,就像什么都没发生一样。

cherry-pick

拣选提交,选择一个commit,合并进当前分支。

状态模型

工作区(workspace)

当前工作空间,也就是在本地文件夹下看到的文件结构。初始化工作空间或者工作空间 clean 的时候,文件内容和 index 暂存区是一致的,随着修改,工作区文件在没有 add 到暂存区时候,工作区将和暂存区是不一致的。

当我们做出了新增/修改,在 add 之前,这些修改还在工作区,通常我们会在 IDE 中设置 默认将修改 add 到暂存区(至少我是这么搞的)。此时文件的状态为 已修改(modified)

暂存区(stage/index)

也被叫做索引,文件暂时存放的地方,所有暂时存放在暂存区中的文件将随着一个 commit 一起提交到 local repository 此时 local repository 里面文件将完全被暂存区所取代。

将工作区的修改 add 了之后,这些修改就在暂存区了。此时文件的状态为 已暂存(staged)

本地仓库(local repository)

即 .git 目录,git 是分布式版本控制系统,和其他版本控制系统不同的是他可以完全去中心化工作,你可以不用和中央服务器 (remote server) 进行通信,在本地即可进行全部离线操作,包括 log,history,commit,diff 等等。完成离线操作最核心是因为 git 有一个几乎和远程一样的本地仓库,所有本地离线操作都可以在本地完成,等需要的时候再和远程服务进行交互。

将暂存区的修改 commit 之后,这些修改就被会提交到本地仓库,并生成 commit 对象。此时文件的状态为 已提交(committed)

远程仓库(remote repository)

开发成员内共享,本地仓库会和远程仓库进行交互,也就能将其他人的修改更新到本地仓库,把自己的修改上传至远程仓库供其他人获取。结构大体和本地仓库一样。

当执行了 push 之后,对应的 commit 就被提交到远程仓库了。

对象模型

git 在本地是有一个完整的 git 仓库也就是 .git 文件目录,通过这个仓库,git 就可以完全离线化操作。在这个本地化的仓库中存储了 git 所有的模型对象。

git 主要有四个对象,分别是 Blob,Tree,Commit,Tag 他们都用 SHA-1 进行命名。SHA-1(Secure Hash Algorithm 1)是一种密码散列函数,即散列加密,SHA-1可以生成一个被称为消息摘要的160位(20字节)散列值,散列值通常的呈现形式为40个十六进制数。

Blob 对象

只用于存储单个文件内容,一般都是二进制的数据文件,不包含任何其他文件信息,比如不包含文件名和其他元数据。

Tree 对象

对应文件系统的目录结构,里面主要有:子目录 (tree),文件列表 (blob),文件类型以及一些数据文件权限模型等。

Commit 对象

是修改过的文件集的一个快照,随着一次 commit 操作,将创建一个 commit 对象,修改过的文件将会被提交到 local repository 中。通过 commit 对象,在版本化中可以检索出每次修改内容,是版本化的基石。

Tag 对象

tag 是一个"固化的分支",一旦打上 tag 之后,这个 tag 代表的内容将永远不可变,因为 tag 只会关联当时版本库中最后一个 commit 对象。一般应用或者软件版本的发布一般用 tag。

存储模型

Svn 等其他的 VCS 对文件版本的理念是以文件为水平维度,记录每个文件在每个版本下的 delta 改变。

Git 对文件版本的管理理念却是以每次提交为一次快照,而不是进行差异比较,提交时对所有修改过的文件做一次全量快照,然后存储快照引用。Git 在存储层,如果文件数据没有改变的文件,Git 只是存储指向源文件的一个引用,并不会直接多次存储文件,这一点可以在 pack 文件中看见。

参考文章&推荐阅读文章来源地址https://www.toymoban.com/news/detail-694881.html

  • 这才是真正的Git——Git内部原理揭秘! - 知乎 (zhihu.com)
  • 一文讲透 Git 底层数据结构和原理 - 知乎 (zhihu.com)
  • Git入门图文教程(1.5W字40图)🔥🔥–深入浅出、图文并茂 - 安木夕 - 博客园 (cnblogs.com)

到了这里,关于Git 基本原理和常用操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Git】Git基本操作

    Git是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目。它采用分布式方式,避免中心服务器的单点故障,保障系统的高可用性和稳定性。Git可以作为一种过渡方案来替代BitKeeper,帮助管理Linux内核开发等。总之,Git是一种高效、灵活的

    2024年02月04日
    浏览(40)
  • 【Git】常用的Git操作集合

    git branch 被 * 标识的分支就是当前代码所在的分支,图示表明当前在 develop 分支。 git branch -a git checkout test 切换到本地的test分支。 git checkout origin master : 切换到远程仓库的master分支。 git status git diff git diff 命令还可以通过指定HEAD指针、版本、文件名等进行更具体的比较。 有

    2024年01月21日
    浏览(27)
  • Git基础——基本的 Git本地操作

            本文涵盖了你在使用Git的绝大多数时间里会用到的所有基础命令。学完之后,你应该能够配置并初始化Git仓库、开始或停止跟踪文件、暂存或者提交更改。我们也会讲授如何让Git忽略某些文件和文件模式,如何简单快速地撤销错误操作,如何浏览项目版本历史并查

    2024年02月11日
    浏览(38)
  • Git第三讲 Git的基本操作

    在使用Git进行版本控制时,有一些基本的操作是必须掌握的。本章将介绍这些基本操作,包括如何添加和提交文件、查看和比较更改、撤销更改以及删除文件等。 Git使用暂存区(或称为索引)来管理文件的更改。添加和提交文件是Git中最常用的操作之一。 添加文件 要将文件

    2024年02月08日
    浏览(42)
  • git原理和常用命令

    git -分布式版本控制系统,可以有效、高速的处理从很小到非常大的项目版本管理。 git特点 优点: 适合分布式开发,强调个体; 公共服务器压力和数据量都不会太大; 速度快、灵活; 任何两个开发者之间可以很容易的解决冲突; 离线工作。 缺点: 代码保密性差,一旦开

    2024年02月09日
    浏览(34)
  • 【Git】从零开始的 Git 基本操作

    要提前说的是, 仓库是进行版本控制的一个文件目录 。我们想对文件进行版本控制,就必须先创建一个仓库出来。 创建一个 Git 本地仓库对应的命令为 git init ,注意命令要在文件目录下执行,例如: 我们发现,当前目录下多了一个 .git 的隐藏文件, .git 目录是 Git 用来跟踪

    2024年04月22日
    浏览(33)
  • Git 的基本概念、使用方式及常用命令

      Git是一个分布式版本控制系统,常用于协同开发和版本管理。以下是Git的基本概念和使用方式以及一些常用命令:   用于存储源代码和版本历史记录的地方。可以是 本地仓库(Local Repository) 或 远程仓库(Remote Repository) 。   存放实际的源代码文件。   用于临时

    2024年01月20日
    浏览(42)
  • 【git常用操作】git的分支创建、切换、提交与关联分支操作

    下拉代码建议用ssh密钥方式下拉 ,配置好之后后续操作不需要输入密码等权限验证操作,很方便。 查看分支: 创建本地分支: 切换本地分支: 创建+切换分支: 将新分支推送到github: 建议使用IDEA集成git来完成下列操作 ,如果使用上面提到的ssh密钥方式下拉工程的话会方便

    2024年02月15日
    浏览(33)
  • Git学习(一)基于本地操作:Git初识、Git安装(Linux-ubuntu)、Git 基本操作、分支管理

    目录 Git 初识 Git 安装(Linux-ubuntu) Git 基本操作 创建 Git 本地仓库 配置 Git 认识工作区、暂存区、版本库 添加文件 查看 .git 文件 修改文件 版本回退 撤销修改 情况一:对于工作区的代码,还没有 add 情况二:已经 add ,但没有 commit 情况三:已经 add ,并且也 commit 了  删除文

    2024年04月08日
    浏览(53)
  • 【Git-9】Eclipse安装Git插件及基本操作

    选择  Help  –  Install New Software... 插件名称自定义, 插件地址为:http://download.eclipse.org/egit/updates/ 。 3.1、选择需要下载安装的插件 3.2、 列出需要下载资源文件,选择  下一步 3.3、同意协议,选择  Finish ,开始安装插件。 旧版本的Eclipse需要配置  TLSv  协议。 ini配置文件

    2023年04月11日
    浏览(24)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包