一篇带你学会Git基础操作

news2025/1/12 5:55:41

📙 作者简介 :RO-BERRY
📗 学习方向:致力于C、C++、数据结构、TCP/IP、数据库等等一系列知识
📒 日后方向 : 偏向于CPP开发以及大数据方向,欢迎各位关注,谢谢各位的支持


请添加图片描述


目录

  • 1.认识⼯作区、暂存区、版本库
  • 2.添加文件---add、commit -m
  • 3.查看 .git ⽂件
  • 4.修改文件
  • 5.版本回退
  • 6.撤销修改
    • 6.1情况⼀:对于⼯作区的代码,还没有 add
    • 6.2情况⼆:已经 add ,但没有 commit
    • 6.3情况三:已经 add ,并且也 commit 了
  • 7.删除⽂件


1.认识⼯作区、暂存区、版本库

学习这个有助于我们今后的学习以及Git工作的流程

• ⼯作区:是在电脑上你要写代码或⽂件的⽬录。
• 暂存区:英⽂叫 stage 或 index。⼀般存放在 .git ⽬录下的 index ⽂件(.git/index)中,我们
把暂存区有时也叫作索引(index)。
• 版本库:⼜名仓库,英⽂名 repository 。⼯作区有⼀个隐藏⽬录 .git ,它不算⼯作区,⽽是 Git 的版本库。这个版本库⾥⾯的所有⽂件都可以被 Git 管理起来,每个⽂件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

我们都知道了git是一个版本管理工具,那我们来试一下如何使用
我们先在git仓库里创建一个文件
请添加图片描述
请添加图片描述
目前情况下Git能否管理readme文件呢?
答案是不行的

我们先来理解几个概念
gitcode其实不能称之为我们的本地仓库
真正的本地仓库其实是这个.git文件
这个仓库又称为版本库

那有人会说我们把readme文件移动到.git仓库里面,那就可以管理了吗?
这也是不行的,这样是不被允许的,同样在git仓库里面创建文件也是不被允许的

在这里我们强调:
不允许在.git下手动修改
一旦我们误改,误删了,整个就用不了了,就报废了
我们的文件只能存在gitcode里面
而我们上面创建的readme文件就是我们的工作区

请添加图片描述

下⾯这个图展⽰了⼯作区、暂存区和版本库之间的关系:
在这里插入图片描述
图中左侧为⼯作区,右侧为版本库。Git 的版本库⾥存了很多东西,其中最重要的就是暂存区。

• 在创建 Git 版本库时,Git 会为我们⾃动创建⼀个唯⼀的 master 分⽀,以及指向 master 的⼀个指
针叫 HEAD。(分⽀和HEAD的概念后⾯再说)
• 当对⼯作区修改(或新增)的⽂件执⾏ git add 命令时,暂存区⽬录树的⽂件索引会被更新。
• 当执⾏提交操作 git commit 时,master 分⽀会做相应的更新,可以简单理解为暂存区的⽬录
树才会被真正写到版本库中。
由上述描述我们便能得知:通过新建或粘贴进⽬录的⽂件,并不能称之为向仓库中新增⽂件,⽽只是
在⼯作区新增了⽂件。必须要通过使⽤ git add 和 git commit 命令才能将⽂件添加到仓库中进⾏管理!!!

注:

  • 第一步就是add工作
    我们会先将工作区修改的内容,添加进我们版本库的暂存区中(修改—新增、修改、删除)
    在暂存区也只是用来暂时存储
  • 第二步就是commit工作
    暂存区会将工作提交到master中,这时候才会叫做把我们的工作提交到管理库中

2.添加文件—add、commit -m

在包含 .git 的⽬录下新建⼀个 readme ⽂件,我们可以使⽤ git add 命令可以将⽂件添加到暂存
区:
• 添加⼀个或多个⽂件到暂存区: git add [file1] [file2] …
• 添加指定⽬录到暂存区,包括⼦⽬录: git add [dir]
• 添加当前⽬录下的所有⽂件改动到暂存区: git add .

再使⽤ git commit 命令将暂存区内容添加到本地仓库中:
• 提交暂存区全部内容到本地仓库中: git commit -m “message”
• 提交暂存区的指定⽂件到仓库区: git commit [file1] [file2] … -m “message”
注意 git commit 后⾯的 -m 选项,要跟上描述本次提交的 message,由⽤⼾⾃⼰完成,这部分内
容绝对不能省略,并要好好描述,是⽤来记录你的提交细节,是给我们⼈看的。

我们先给我们的readme文件加入一点数据
请添加图片描述
我们来做以下add操作
请添加图片描述
第二步就是commit操作
请添加图片描述
其实可以使用一个代码将所有的文件都加入到版本库中
我们先多创建几个文件
请添加图片描述
我们在介绍一个命令就是
git log
他可以帮我们打印所有的时间从近到远的所有提交记录,修改记录
请添加图片描述
该命令显⽰从最近到最远的提交⽇志,并且可以看到我们 commit 时的⽇志消息。
如果嫌输出信息太多,看得眼花缭乱的,可以试试加上 --pretty=oneline 参数:请添加图片描述
需要说明的是,我们看到的⼀⼤串类似 23807c5…56eed6 的是每次提交的 commit id (版本
号),Git 的 commit id 不是1,2,3……递增的数字,⽽是⼀个 SHA1 计算出来的⼀个⾮常⼤的数
字,⽤⼗六进制表⽰(你看到的 commit id 和我的肯定不⼀样,以你⾃⼰的为准)

请添加图片描述
为了加深我们对工作区与暂存区还有版本库的印象
我们再举一个例子
请添加图片描述


3.查看 .git ⽂件

先来看看我们的 .git 的⽬录结构:
在这里插入图片描述
下面还有一点
在这里插入图片描述

  1. index 就是我们的暂存区,add 后的内容都是添加到这⾥的。
  2. HEAD 就是我们的默认指向 master 分⽀的指针:

在这里插入图片描述
⽽默认的 master 分⽀,其实就是:
在这里插入图片描述
打印的2e5d53102925463f924f3a0317b0303f46744e57是什么东西呢?保存的就是当前最新
的 commit id.

  1. objects 为 Git 的对象库,⾥⾯包含了创建的各种版本库对象及内容。当执⾏ git add 命令
    时,暂存区的⽬录树被更新,同时⼯作区修改(或新增)的⽂件内容被写⼊到对象库中的⼀个新的
    对象中,就位于 “.git/objects” ⽬录下,让我们来看看这些对象有何⽤处:

在这里插入图片描述
查找 object 时要将 commit id 分成2部分,其前2位是⽂件夹名称,后38位是⽂件名称。
找到这个⽂件之后,⼀般不能直接看到⾥⾯是什么,该类⽂件是经过 sha (安全哈希算法)加密过的
⽂件,好在我们可以使⽤ git cat-file 命令来查看版本库对象的内容:

在这里插入图片描述
这是我最近一次的删除操作
其中,还有⼀⾏ tree d883b5ffc63e4d9f105f4e3a666f2269be45be70 ,我们使⽤同样的⽅
法,看看结果:
在这里插入图片描述
在看 readme 对应的 5a3131802924a906199474f83849abb94b2cae7
在这里插入图片描述
这是我们对ReadMe做的修改!!被git记录了下来!!
总结⼀下,在本地的 git 仓库中,有⼏个⽂件或者⽬录很特殊
• index: 暂存区, git add 后会更新该内容。
• HEAD: 默认指向 master 分⽀的⼀个指针。
• refs/heads/master: ⽂件⾥保存当前 master 分⽀的最新 commit id 。
• objects: 包含了创建的各种版本库对象及内容,可以简单理解为放了 git 维护的所有修改。
后⾯再学习过程中,最好能将常⻅的 git 操作与 .git ⽬录当中的结构内容变化对应起来,这样有
利于我们理解git 细节流程。我们后⾯还会学习什么分⽀,标签什么的,那我想后⾯同学就应该学习对
应着研究了!


4.修改文件

Git ⽐其他版本控制系统设计得优秀,因为 Git 跟踪并管理的是修改,⽽⾮⽂件。
什么是修改?⽐如你新增了⼀⾏,这就是⼀个修改,删除了⼀⾏,也是⼀个修改,更改了某些字符,
也是⼀个修改,删了⼀些⼜加了⼀些,也是⼀个修改,甚⾄创建⼀个新⽂件,也算⼀个修改。
让我们将 ReadMe ⽂件进⾏⼀次修改:
![请添加图片描述](https://img-blog.csdnimg.cn/direct/a8bd0743f62e4f3da7ccf9e95bd8e2b1.png
然后保存退出
我们使用git status指令
这个指令代表的是我们上次提交到现在文件是否发生了修改

请添加图片描述
status命令可以用来看仓库的一些状态
⽬前,我们只知道⽂件被修改了,如果能知道具体哪些地⽅被修改了,就更好了。有同学会说,我刚
改的我知道呀!可是,你还记得你三天前写了什么代码吗?或者没写?
git diff [file] 命令⽤来显⽰暂存区和⼯作区⽂件的差异,显⽰的格式正是Unix通⽤的diff格
式。也可以使⽤ git diff HEAD – [file] 命令来查看版本库和⼯作区⽂件的区别。
请添加图片描述
我们再进行提交,再次观察status指令操作
请添加图片描述
这代表了工作区是干净的并没有什么改变


5.版本回退

之前我们也提到过,Git 能够管理⽂件的历史版本,这也是版本控制器重要的能⼒。如果有⼀天你发现
之前前的⼯作做的出现了很⼤的问题,需要在某个特定的历史版本重新开始,这个时候,就需要版本
回退的功能了。
执⾏ git reset 命令⽤于回退版本,可以指定退回某⼀次提交的版本。要解释⼀下“回退”本质是要将版本库中的内容进⾏回退,⼯作区或暂存区是否回退由命令参数决定:
git reset 命令语法格式为:

git reset [–soft | --mixed | --hard] [HEAD]
• --mixed 为默认选项,使⽤时可以不⽤带该参数。该参数将暂存区的内容退回为指定提交版本内
容,⼯作区⽂件保持不变。
• --soft 参数对于⼯作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。
• --hard 参数将暂存区与⼯作区都退回到指定版本。切记⼯作区有未提交的代码时不要⽤这个命令,因为⼯作区会回滚,你没有提交的代码就再也找不回了,所以使⽤该参数前⼀定要慎重。

• HEAD 说明:
◦ 可直接写成 commit id,表⽰指定退回的版本
◦ HEAD 表⽰当前版本
◦ HEAD^ 上⼀个版本
◦ HEAD^^ 上上⼀个版本
◦ 以此类推…
• 可以使⽤ 〜数字表⽰:
◦ HEAD~0 表⽰当前版本
◦ HEAD~1 上⼀个版本
◦ HEAD^2 上上⼀个版本
◦ 以此类推…

在这里插入图片描述

我们的readme文件里面有两行代码
实际上是我们分两次加入
第一个版本是只有hello world的

我们将用git reset进行版本回退
其本质是回退的版本库中的内容
在这里插入图片描述
在这里mixed是我们reset的默认选项,如果我们reset后面什么都不加的话,会默认为reset --mixed
我们使用hard要注意,使用了之后我们写的代码都会消失不见,我们可能写了好几天的代码,所以我们要慎用
我们来尝试一下
先来查看一下日志
在这里插入图片描述
这里显示了我们前几次的操作
我们想嫁给readme文件回退到第一个版本,就是我们第一次add first file时候的版本
我们使用一下reset hard
在这里插入图片描述
在这里我们要复制add first file的编码
在这里插入图片描述
现在已经成功回退了
在这里插入图片描述
我们可以看到,我们的文件都不见了,a5是之前没有添加进工作区的
我们再打印一次日志
在这里插入图片描述
所有的工作都不见了, 只有add first file工作记录了
而readme文件也回到第一个版本
在这里插入图片描述.
那我们这些文件数据都消失了,我们操作失误了怎么办,能不能回到曾经的状态呢?
我们依然还是使用回退功能
使用reset --hard
在这里插入图片描述
在这里我们使用上原来最近一次的文件修改id,回退到最开始的地方
在这里插入图片描述
这样文件以及内容都回来了
在这里插入图片描述
我们能回退是因为原来的操作id并没有清除
我们可以看到上面的id信息
但是如果我们将服务器关闭或者将这一页清除了,我们看不到上面的id信息了怎么办?
我们还能实现恢复吗?
但是还可以
我们使用命令
git reflog

在这里插入图片描述
我们的回退以及中间文件的每一次修改他都有所记录,我们使用里面前面跟着的commit_ID就可以,这里的ID为什么这么短呢?
这其实也是那个大长串的ID的一部分,也能支持我们实现回退


6.撤销修改

如果我们在我们的⼯作区写了很⻓时间代码,越写越写不下去,觉得⾃⼰写的实在是垃圾,想恢复到上⼀个版本

6.1情况⼀:对于⼯作区的代码,还没有 add

你当然可以直接删掉你⽬前在⼯作区新增的代码,像这样:
我们新增了三行代码,我们没有实现add操作,我们可以直接进行文件编辑进行删除
在这里插入图片描述
⾟亏我们⼯作效率不⾼,才写了三⾏代码就发现不⾏了,要是你写了3天,⼀直都没有提交,该怎么删掉呢?你⾃⼰都忘了⾃⼰新增过哪些,有同学说,我可以 git diff xxx ⼀下,看看差别再删啊,那你肯定⼜要花3天时间删代码了,并且很⼤的概率还会改出bug。⼀周过去了,你怎么向你的⽼板交代呢?

Git 其实还为我们提供了更好的⽅式,我们可以使⽤ git checkout – [file] 命令让⼯作区的⽂件回到最近⼀次 add 或 commit 时的状态。 要注意 git checkout – [file] 命令中的-- 很重要,切记不要省略,⼀旦省略,该命令就变为其他意思了,后⾯我们再说。⽰例如下:
在这里插入图片描述
我们发现文件变回修改前了,这个是将我们工作区的文件回退到上一次的版本
相比于上方的reset,这个简单很多,而且reset容易失误,这个明显更优


6.2情况⼆:已经 add ,但没有 commit

add 后还是保存到了暂存区呢?怎么撤销呢?
我们再来新增一行代码
在这里插入图片描述
我们顺势add
在这里插入图片描述
这里可以看到我们已经提交到暂存区
让我们来回忆⼀下学过的 git reset 回退命令,该命令如果使⽤ --mixed 参数,可以将暂存区的内容退回为指定的版本内容,但⼯作区⽂件保持不变。那我们就可以回退下暂存区的内容了!!!
mixed是默认可以省略
在这里插入图片描述
⽤ git status 查看⼀下,发现现在暂存区是⼲净的,⼯作区有修改
在这里插入图片描述
还记得如何丢弃⼯作区的修改吗?
我们使用checkout --即可
在这里插入图片描述
恢复了!


6.3情况三:已经 add ,并且也 commit 了

不要担⼼,我们可以 git reset --hard HEAD^ 回退到上⼀个版本!不过,这是有条件的,就是
你还没有把⾃⼰的本地版本库推送到远程。还记得Git是分布式版本控制系统吗?我们后⾯会讲到远程版本库,⼀旦你推送到远程版本库,你就真的惨了……
我们向文件中添加一点数据,并实现添加以及提交
在这里插入图片描述
我们使用git reset --hard HEAD^,将所有部分都进行回退
在这里插入图片描述
文件恢复了
在这里插入图片描述
工作区与暂存区也没有任何东西

值得说的是,Git 的版本回退速度⾮常快,因为 Git 在内部有个指向当前分⽀(此处是master)的HEAD 指针, refs/heads/master ⽂件⾥保存当前 master 分⽀的最新 commit id 。当我们在回退版本的时候,Git 仅仅是给 refs/heads/master 中存储⼀个特定的version,可以简单理解成如下⽰意图:
在这里插入图片描述
在这里插入图片描述


7.删除⽂件

在 Git 中,删除也是⼀个修改操作
在这里插入图片描述
我们实战⼀下, 如果要删除 a4 ⽂件,怎么搞呢?
如果你直接使用linux指令rm删除文件
在这里插入图片描述
这样直接删除是没有⽤的,反⽽徒增烦恼, git status 命令会⽴刻告诉你哪些⽂件被删除了
在这里插入图片描述
此时,⼯作区和版本库就不⼀致了,要删⽂件,⽬前除了要删⼯作区的⽂件,还要清除版本库的⽂件。
⼀般⾛到这⾥,有两种可能:
• 确实要从版本库中删除该⽂件
• 不⼩⼼删错了
对第⼆种情况,很明显误删,需要使⽤ git 来进⾏恢复,很简单,我们刚学过(删除也是修改):
在这里插入图片描述
对于第⼀种情况,很明显是没有删完,我们只删除了⼯作区的⽂件。这时就需要使⽤ git rm 将⽂
件从暂存区和⼯作区中删除,并且 commit
我们git也有工作区删除命令 git rm 【文件】
在这里插入图片描述
我们查看状态,看到删除了a4,并且暂存区有信息需要提交到版本库
在这里插入图片描述
这样我们的工作区以及暂存区都干净了
现在,⽂件就从版本库中被删除了

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

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

相关文章

CMU15-445 Project0

CMU14445 Task #1 - Copy-On-Write Trie Get()思路: 获取根节点指针,顺着key逐字符往下找节点,最后根据题意可以使用dynamic_cast检查是否是TrieNodeWithValue(dynamic_pointer_cast也可以),以下为两者用法&#xff1…

OpenHarmony关系型数据库

1 概述 关系型数据库(Relational Database, 以下简称RDB)是一种基于关系模型来管理数据的数据库,是在SQLite基础上提供一套完整的对本地数据库进行管理的机制,为开发者提供无需编写原生SQL语句即可实现数据增、删、改、查等接口,同时开发者也…

css设置不可点击

文章目录 一、前言二、MDN三、使用四、注意五、总结六、最后 一、前言 在网页开发中,经常会遇到一种情况,就是需要将某个元素的点击事件屏蔽,使其在用户点击时没有任何反应。这时候,我们可以通过CSS的pointer-events属性设置为no…

Jmeter接口测试总结

🍅 视频学习:文末有免费的配套视频可观看 🍅 关注公众号【互联网杂货铺】,回复 1 ,免费获取软件测试全套资料,资料在手,涨薪更快 Jmeter介绍&测试准备 Jmeter介绍:Jmeter是软件…

PositiveSSL多域名通配符证书买一年送一月

SSL数字证书是一种安全协议,用于在网络通信中提供加密和身份验证服务,是保护网站安全的重要手段之一。PositiveSSL是Sectigo旗下的子品牌,经营着各种SSL证书,例如,单域名SSL证书、多域名SSL证书、通配符SSL证书和多域名…

Java通过模板替换实现excel的传参填写

以模板为例子 将上面$转义的内容替换即可 package com.gxuwz.zjh.util;import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.io.*; import java.util.HashMap; import java.util.Map; import java.io.IOException; impor…

RISC-V RVWMO 内存模型解释

RISC-V RVWMO 内存模型解释 引言 本文介绍 RISC-V RVWMO 内存模型。RVWMO 内存模型定义了什么样的全局内存顺序才是合法的。本引言部分将解释为什么会出现不合法的全局内存顺序,以及为什么需要内存模型。 首先引起乱序的全局内存顺序(指令重排序&…

AI作画工具 stable-diffusion-webui 一键安装工具(A1111-Web-UI-Installer)

安装 下载最新版本确保你的 NVIDIA 显卡驱动程序是最新的(起码不能太老)启动安装程序在欢迎屏幕上单击下一步在屏幕上,选择要安装的内容如果你已经安装了 Python 3.10 和 Git,那么可以取消选中如果你不知道这些是什么&#xff0c…

精品基于Uniapp+springboot助农管理系统App农产品积分购物商城

《[含文档PPT源码等]精品基于Uniappspringboot助农管理系统App》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功! 软件开发环境及开发工具: 开发语言:Java 后台框架:springboot、ssm 安卓…

解析MySQL生产环境CPU使用率过高的排查与解决方案

引言 在生产环境中,MySQL作为一个关键的数据库组件,其性能对整个系统的稳定性至关重要。然而,有时候我们可能会遇到MySQL CPU使用率过高的问题,这可能导致系统性能下降,应用页面访问减慢,甚至影响到用户体…

数据结构与算法——队列

概述 计算机科学中,queue 是以顺序的方式维护的一组数据集合,在一端添加数据,从另一端移除数据。添加的一端称为尾,移除的一端称为头。 功能 插入offer(value : E) : boolean  取值并移除poll() : E  取值peek() : E  判断…

Redis案例-微信抢红包

Redis案例-微信抢红包 1、业务描述 ​ 微信红包,一个人能发红包,红包的分发规则,红包能被几个人抢,超过24小时没有人领取自动退回原账户,红包详情页面有每个人的抢红包记录,包括金额大小和时间&#xff0…

统计学-R语言-7.3

文章目录 前言总体方差的检验一个总体方差的检验两个总体方差比的检验 非参数检验总体分布的检验正态性检验的图示法Shapiro-Wilk和K-S正态性检验总体位置参数的检验 练习 前言 本篇文章继续对总体方差的检验进行介绍。 总体方差的检验 一个总体方差的检验 在生产和生活的许多…

使用BootStrapBlazor组件搭建Bootstarp风格的Winform界面

项目地址https://gitee.com/zhang_jie_sc/my-blazor-winforms 1.安装Bootstrap.Blazor.Templates 模板 在power shell中输入dotnet new install Bootstrap.Blazor.Templates::7.6.1,安装7.6.1是因为版本8以后就要强制使用net8.0了,很多语法不一样&…

了解WPF控件:ToggleButton和Separator常用属性与用法(十三)

掌握WPF控件:熟练ToggleButton和Separator常用属性(十三) ToggleButton 一个按钮类UI元素,它的特点是拥有两种状态:选中(Checked)和未选中(Unchecked)。当用户单击Togg…

pve8.1 安装、创建centos7虚拟机及配置

之前创建虚拟机centos7时,硬盘分配太大了,做成模板后无法进行修改了,安装完pve8.1后,强迫症犯了重新创建一下顺便记录一下配置过程。由于目前centos7还是生产用的比较多的版本所以本次还是安装centos7.9版本。 一、下载镜像 下载…

使用 CDC MinIO 汇入端为 CockroachDB 保持持久数据

CockroachDB 数据库迅速崭露头角,作为一个坚韧且可扩展的分布式 SQL 数据库。它从其昆虫名字的坚持不懈中汲取灵感,即使面对硬件故障,CockroachDB 也能保证高可用性。其分布式架构横跨多个节点,类似于其昆虫原型的适应性。 凭借强…

dos攻击与ddos攻击的区别

①DOS攻击: DOS:中文名称是拒绝服务,一切能引起DOS行为的攻击都被称为dos攻击。该攻击的效果是使得计算机或网络无法提供正常的服务。常见的DOS攻击有针对计算机网络带宽和连通性的攻击。 DOS是单机于单机之间的攻击。 DOS攻击的原理&#…

JavaScript学习-原型和原型链

原型和原型链 示例代码 //创建一个Person类 class Person {constructor(name) {this.name name;}drink() {console.log(喝水);} } //创建一个Teacher类,继承Person class Teacher extends Person {constructor(name, subject) {super(name);this.subject subjec…

详细解读vcruntime140_1.dll修复的手段,如何快速解决vcruntime140_1.dll丢失问题

当出现“无法找到vcruntime140_1.dll”或程序“未能正常启动”时,这通常指示系统中缺失了一个关键文件:vcruntime140_1.dll。作为Visual C Redistributable组件的一部分,这个小文件在很多用Visual Studio编译的C程序运行时发挥着重要作用。解…