git 的基本操作

news2025/1/10 17:58:14

1. git建立本地仓库

在想要建立的目录下输入命令

git init

我们可以看一下 .git目录下有什么

 

2. 配置git本地仓库 

配置用户的 name 和 email

命令:git config [...]

配置完后,我们像查看一下 刚才的配置

2.1 查看配置命令

git config -l

2.2 删除配置 

命令:git config --unset [...]

查看配置

 

配置已经删除了

2.3 全局配置 

解释:在我们的一台服务器上有时候并不是只有一个git仓库,如果我们想要全局配置的话需要加一个选项 --global

git config --global [...]

 查看配置项

2.4 删除全局配置 

删除全局配置的话 只有 --unset 是不可以的,需要加上 --global 选项

 

3. 认识 git 工作区、暂存区、版本库

3.1 我们在gitcode目录下创建一个ReadMe文件,并查看

  1.  其中,ReadMe文件目前并未被git所管理, 因为当前的gitcode目录,并非真的git仓库,二gitcode目录下的隐藏文件 .git目录才是真的 版本库(仓库),但是我们并不可以手动的在 .git目录下修改文件(创建/删除 等...),所以 ReadMe文件就是工作区

但是,我们的工作区的文件并不是不可以被管理,我们需要做一些工作,看上图,

    2. 我们图片上的 stage 区域,就是暂存区/索引

3.2 对工作区文件的管理

3.2.1 add 

我们将工作区的的修改(新增、修改、删除),我们通过add,可以将修改的内容添加到暂存区,但是这并不算添加到版本库中

3.2.2 commit

在我们add之后,我们只有进行commit后才会把修改的内容存到版本库中

我们只有做完这两步,我们的git才能管理这个 ReadMe 文件

3.3 如何理解 git管理文件(add操作)

其实在我们的版本库中,还有一个objects 对象,我们的objects中存的是一个个的git对象,而我们 每一次add的时候(对工作区的修改的内容),都会存在一个新的git对象中,所以我们维护的这些 git对象,也就是对这些文件进行版本管理

我们的stage 中存的是索引,指向objects

 3.4 commit

我们在commit后,就会把暂存区的内容存到master 中,而我们的master中也存的是索引

而我们想要拿到我们的master分支,我们只需要拿到 HEAD 指针,就好了 

我们可以对应的看一下 .git目录 和上面的图片

但是我们的.git目录里面没有stage,因为 stage里面是暂存区,我们的git仓库是刚创建的,还没有暂存的内容,所以我们的.git目录里面还没有stage

4.  git 添加文件_场景1

我们现在ReadMe文件中写入一些内容

然后我们使用add,将 ReadMe文件添加到暂存区

git add [...] :表示指定文件的修改内容添加到暂存区

git add .     :表示将所有的文件的修改内容添加到暂存区

git commit -m "这里面描述修改内容" ,这个-m必不可少,-m后面是本次版本的修改内容

commit 后,会打印日志

5. 查看最近提交 

git log

如果觉得这样太乱的话,可以加 --pretty=oneline 打印一行

 

6. 查看git文件 

我们先看一下我们gitcode目录下的.git目录

我们现在看一下,我们的.git/HEAD 

我们看到,我们的HEAD下有一个master

而我们知道,我们最后的内容都会存到master分支里面,我们看一下

 

我们看到我们的master里面是一串上面这样的文本,而我们注意,我们在上面commit后打印的日志里面就有这样内容

而我们的master存的就是索引,我们的索引最终都指向 objects

我们在看一下我们的 .git 目录里面的 objects目录

 

我们看前面的这两个,前面的这两位代表文件名,而后面的就代表d7里面的文件名了

如果我们想要查看里面的文件内容,我们的命令是:

git cat-file -p 

这里面还有我们第一次提交的信息,我们再看一下我们该信息里面的 tree

 我们继续看一下 

我们看到,又打印出了一条信息,我们继续使用git cat-file -p 查看

 

我们看到了我们所写入的内容 

 7. git添加文件_场景2

我们先创建1个文件file1 然后 add 

我们又创建一个文件 file2 

然后我们 commit

我们原意是将file1 和 file2 都commit ,但是这里只有一个文件被changed 说明只有一个文件被修改,我们的file2没有被提交,因为我们的add是将文件放到暂存区(stage),我们的commit是将暂存区的文件给存到master分支中,我们的file2没有存到暂存区(也就是没有add),所以不可以被commit,如果我们想要将file2也存到master中,我们就继续对file2 进行add ,然后commit

8. 修改文件 

实际上 git 追踪的是修改而不是文件

我们先将 hello world 修改为 hello git

8.1 查看文件是否被修改 

git status

但是我们的 git status 并不能知道我们修改的内容

8.2 查看文件被修改的内容

git diff [...]

 

上面的图片里面的内容可以看一下代表什么 

8.3 提交修改文件

git add后我们查看 git status

我们的这里的提示改变了,显示我们需要将改变commit 

我们可以看一下没有add之前的提示

这里显示我们没有暂存区(stage)的内容需要提交

所以我们现在 commit 后继续用 git status 查看

 

9. git版本回退

版本回退:版本回退就是从当前版本回退到之前的某一个版本

命令:git reset [--soft | --mixed | --hard] [HEAD]

git reset 本质:回退的版本库中的内容

我们的git中是由三个区的分别是

1.工作区

2.暂存区

2.版本库

其中我们的git reset回退的结果是什么,由git reset 后面的三个选项觉得

  • soft:只回退版本库
  • mixed:回退版本库和暂存区,不会回退工作区
  • hard:全部回退
  • 默认:mixed

我们之前的提交

那么当我们想要回退到第一次提交,我们使用 hard

 

我们将第一次提交的那一串ID粘贴到后面,然后我们看到打印了一条日志

 

我们现在看到,我们之前提交的 file1 file2已经在工作区都回退了

我们继续查看log

  我们这次的log 只剩下第一次提交的内容了

如果我们后悔了刚才的回退,那么我们怎么样?

我们还是使用 git reset 命令

我们找到刚才回退之前查看的log,找到最后一次提交的ID

我们看一下工作区的文件和log

 

那么如果我们找不到之前的commit ID 呢?

9.1查看之前提交ID

git reflog

 

我们前面的这一部分也是提交ID,我们同样也可以使用前面的这个ID进行回退

我们先看一下现在的提交信息

我们使用git reset进行回退,这次使用reflog前面的ID

我们回退之后我们在查看一下log

 

10. 撤销修改 

我们现在已经有一个文本了,我们对已有文本进行修改,有三个场景

1.我们只对我们工作区的文本进行的修改

2.我们随工作区的文本进行修改后,还进行的add

3.我们不仅修改了工作区的文本,还add了,最后还commit了

我们的撤销操作对于这三种情况下是不同的

10.1 我们只对工作区进行了修改

 

 我们想对工作区的文本进行撤销

命令:git checkout -- 

我们看一下ReadMe文档

 

git checkout -- 表示将工作区恢复到最近一次add/commit的状态

10.2 工作区和暂存区都修改

 

我们要是想回退到之前的状态我们应该怎么做?

命令:git reset           该命令不仅可以回退到之前版本还可以回退到当前版本

gti reset HEAD :HEAD代表回退到当前版本,如果想回退到上一个版本我们还可以在HEAD后面加^, 加一个^代表回退到上一个加两个 ^代表回退到上面两个版本

由于我们的暂存区已经修改,所以我们可以使用 --mixed / --hard, --hard会直接将工作区版本也回退, --mixed只能回退暂存区的,所以把暂存区回退后就是第一种情况了

我们在看一下status

 

我们的暂存区已经回退了

下面我们在使用第一种情况下的处理方法

 

我们看到这样就回退了

 

10.3 工作区、暂存区、版本库都修改了

 前提:在我们commit后并没有push操作

 

 

 

我们的工作区、暂存区、版本库都修改了,所以我们使用 git reset --hard 操作撤销

 

10.4 总结 

 

 11. 删除文件

我们删除掉file1

我们使用 git 提供的 rm 删除操作

我们看一下git rm 的作用

1.删除了工作区的文件

 

 2.删除了暂存区的文件

所以我们只需要最后commit就可以了

 

我们最后看一下status

 

我们的工作区以及没有要提交的了

 

git 的基本操作就到这里~

下一次讲 git 分支管理

 

 

 

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

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

相关文章

【CS144-2021】Stanford 计算机网络课程学习

CS144 2019 Fall:https://kangyupl.gitee.io/cs144.github.io/2020 Fall:https://github.com/lawliet9712/Stanford-CS144-2021【推荐】2021 Fall:https://github.com/Kiprey/sponge 前前后后弄了半个月,终于啃完 CS144 了&#…

VLAN基础知识3_VLAN间三层通信(单臂路由)

目录 1.VLAN单臂路由简介 2.基于单臂路由VLAN间三层通信原理 3.VLAN间三层通信单臂路由实验 3.1 常用配置命令 3.2 实验配置步骤 3.3实验效果 1.VLAN单臂路由简介 单臂路由(One-Arm Router)是一种网络拓扑结构,其中一个路由器的一个接…

动手写一个 Java JWT Token 生成组件

OAuth2 中默认使用 Bearer Tokens (一般用 UUID 值)作为 token 的数据格式,但也支持升级使用 JSON Web Token(JWT) 来作为 token 的数据格式。实际来说,OAuth 规范中并无限制 Token 采取何种格式。今天我们就采用 JWT 来作为 Token,它的一个好…

四种缓存的避坑总结

背景 分布式、缓存、异步和多线程被称为互联网开发的四大法宝。今天我总结一下项目开发中常接触的四种缓存实际项目中遇到过的问题。 JVM堆内缓存 JVM堆内缓存因为可以避免memcache、redis等集中式缓存网络通信故障问题,目前还在项目中广泛使用。 堆内缓存需要注…

FFmpeg5.0源码阅读——avformat_find_stream_info

摘要:在使用FFmpeg库时通常使用avformat_find_stream_info相关函数来探测流的基本信息,为了更加深入理解FFmpeg的基本流程,本文根据FFmpeg 5.0的源码详细描述了该函数的具体实现。   关键字:FFmpeg   读者须知:读者…

数学之美:神奇的杨辉三角形,比帕斯卡早了近600年,致敬中国古代数学家(63)

小朋友们好,大朋友们好! 我是猫妹,一名爱上Python编程的小学生。 和猫妹学Python,一起趣味学编程。 今日主题 什么是杨辉三角形? 杨辉三角形有什么规律? 中国古代数学家杨辉。 西方科学家帕斯卡。 杨…

【开源与项目实战:开源实战】81 | 开源实战三(上):借Google Guava学习发现和开发通用功能模块

上几节课,我们拿 Unix 这个超级大型开源软件的开发作为引子,从代码设计编写和研发管理两个角度,讲了如何应对大型复杂项目的开发。接下来,我们再讲一下 Google 开源的 Java 开发库 Google Guava。 Google Guava 是一个非常成功、…

智能指针类模板:auto_ptr、unique_ptr、shared_ptr的原理与使用

1. 什么是智能指针 智能指针是行为类似于指针的类对象,通常用于管理动态内存分配。C程序通常手动动态分配堆内存,但如果动态分配的内存没有释放,则会发生内存泄漏。 例如代码段1.1。 // 代码段1.1 void demo() {double *pd new double;*pd…

使用STM32F103的串口实现IAP程序升级功能

使用STM32F103的串口实现IAP程序升级功能 🎬IAP程序烧录全过程演示: ✨这几天折腾IAP升级功能,狂补了很多相关BootLoader相关的知识。本来最想实现IAP升级程序的方式是,基于SPI通讯的SD卡,借助挂载的FatFS文件系统&am…

C++中的内存分区

目录 操作系统的内存区域 C内存分区模型 1. 程序运行前 2. 程序运行后 3. new 操作符的使用 操作系统的内存区域 text段:存储程序的二进制指令,即程序源码编译后的二进制代码data段:存储已被初始化的全局变量、常量bss段:存储…

ES-工作原理

前言 ​ 搜索引擎是对数据的检索,而数据总体分为两种:结构化数据和非结构化数据。而对于结构化数据,因为他们具有特定的结构,所以一般都是可以通过关系型数据库MySQL/oracle的二维表的方式存储和搜索,也可以建立索引。…

Redis的简单使用 (实现Session持久化)

🎉🎉🎉点进来你就是我的人了博主主页:🙈🙈🙈戳一戳,欢迎大佬指点! 欢迎志同道合的朋友一起加油喔🤺🤺🤺 目录 一、Redis数据类型的使用 1. 字符串&#xff…

Redis【入门篇】---- Redis的Java客户端-Jedis

Redis【入门篇】---- Redis的Java客户端-Jedis 1. Jedis快速入门2. Jedis连接池1. 创建Jedis连接池2. 改造原始代码 在Redis官网中提供了各种语言的客户端,地址:https://redis.io/docs/clients/ 其中Java客户端也包含很多: 标记为❤的就是推荐…

密码学证明方案寒武纪大爆发——扩容、透明性和隐私的变革潜力

1. 引言 前序博客有: ZKP大爆炸 本文主要参考: StarkWare 2023年6月博客 Cambrian Explosion of Cryptographic Proofs----The transformative potential for scalability, transparency, and privacy2023年3月Eli Ben-Sasson在The 13th BIU Winter …

JavaWeb之Cookie和Session

文章目录 CookieCookie基本介绍Cookie的基本使用Cookie的创建从服务器获取CookieCookie值的修改方案一方案二 浏览器查看CookieCookie声明控制Cookie有效路径Path的设置 SessionSession基本介绍Session的创建和获取(id号,是否为新)Session域数…

【SQL server关键字】

目录: 前言一、CREATE -- 创建二、INSERT INTO VALUES -- 插入数据三、SELECT FROM -- 查找数据1.SEKECT简单了解2.函数的使用3.选择列表与group by子句的对应4.exists子查询 四、UPDATE SET -- 更改数据五、ALTER -- 修改属性六、JOIN ON-- 链接多个表1. join初…

JDBC 望舒客栈项目 万字详解

目录 一、前言 二、项目结构 三、准备工作 1.建立子包 : 2.导入jar包 : 3.工具类 : 1 Utility工具类 2 JDBCUtilsDruid工具类 4.导入配置文件 : 5.引入BasicDAO : 四、项目主体 1.界面显示 : 1 代码演示 2 运行测试 2.用户登录 : 1 创建员工表employee 2 创建Ja…

JavaScript 事件加载有哪些应用场景?

💂 个人网站:【海拥】【游戏大全】【神级源码资源网】🤟 前端学习课程:👉【28个案例趣学前端】【400个JS面试题】💅 寻找学习交流、摸鱼划水的小伙伴,请点击【摸鱼学习交流群】 目录 前言什么是JavaScript事…