小白的git入门教程(二)

泥闷嚎

今天接着来学习小白入门git的基本过程
今天要学习的是git里面的常见操作

  1. 状态查看
    git status
    所谓的状态查看就是你可以查看到工作区和暂存区的状态,在这里你可以看到你的工作文件的状态,比如是否已经提交等等
    在这里插入图片描述
  • 首先我们创建一个文本文件,使用vim编辑器进行创建文件vim test.txt
    在这里插入图片描述
    ll查看查看本地库中的文件,发现除了隐藏git外无其他存在
    这是执行vim test.txt

在这里插入图片描述
这时候进入了vim编辑器,接着我们要对这个文本进行文本的输入

  • i进入输入文本模式

  • 输入文本,为了之后的版本回溯观察方便我这边是输入字符a
    在这里插入图片描述

  • 紧接着写完文字退出vim编辑器,按ESC再输入:wq,即可退出vim编辑器
    在这里插入图片描述

  • 这时候便保存成功文件,我们可以ll查看文件
    在这里插入图片描述

  • 这时候我们git status查看文本状态
    在这里插入图片描述

  1. 添加
    可以发现刚创建写好的文本test.txt为未被跟踪的文件,这时候我们要将其从工作区提交到暂存区
    使用git add test.txt
    再使用git status进行查看文件状态
    在这里插入图片描述
    可以看到此时文件已经从untracked->new files,说明已经暂存到暂存区
  2. 提交
    为了将文件提交到本地库,我们需要将文件从暂存区提交到本地库
    使用git commit -m"message infor"[files name]
    message infor是指你给文件的备注,比如我们这里就用first upload来命名
    我们使用git commit -m"first upload" test.txt
    在这里插入图片描述
    此时我们的文件已经完美存储到本地库中并且文件备注是first upload
  3. 修改文件
    这时候肯定有人会想说文件传到本地库之后还可以更改里面的信息吗,其实是可以的!
    我们只需要再次启动vim编辑器,编辑你的文本,我做个示范,修改我的test.txt文件
  • vim test.txt
    为了后序我们查看历史记录方便,我就这次添加字符b,保存退出
    在这里插入图片描述

  • 保存退出后,我们还要重新对修改后的文件进行提交到本地库的操作

  • 首先是git add test.txt

  • 然后git commit -m"second upload" test.txt这里我们再次上传修改后的文件时,也要进行一次文件信息备注,这里我就备注了我的second upload!
    在这里插入图片描述

  • 这里我又在后台多次按照字母顺序添加字幕c、d以此类推,且文件提交备注也按照顺序third、fourth进行备注!

  1. 查看历史记录

这里指的是你在本地库进行的所有操作,包括新建文件,修改文件等等

这里我最推荐的是git reflog的操作
在这里插入图片描述
其余的查看历史操作我简单一笔带过,具体实现靠自己

git log
git log --pretty=online
git log --oneline

我的选择理由:git reflog中获取的前面的一串字符对于接下来的版本回溯前进后退有很大的作用,其余的版本历史记录查找得到的前置字符太长且不美观!

  1. 日志的前进后退
    我们先git reflog查看一下页面
    在这里插入图片描述
    我们可以注意到红色边框中有一个HEAD,我们可以联想到c语言中的指针,没错,日志存储类似于一个链表,且是头插法建表,因此最新日志永远是做出的最新的更改!
    那么我们便可以基于这个层次进行版本的前进后退

这里我只介绍我一个最推荐的操作——基于索引值操作

  • 所谓的索引便是红框中的head[num]
  • 在这里插入图片描述

使用指令git reset --hard [索引值]
再做此操作之前,还记得我们在创建文本以及修改文件时做的操作吗,一次只输入一行相同的字幕以及备注是按照数字递增的预备操作吗,这便是为我们更好理解版本回溯所做的基础准备

  • 先查看下当前文本中的内容,使用cat test.txt
    在这里插入图片描述

  • 进行版本回溯!先git reflog查看不同版本的索引值
    在这里插入图片描述
    我们目前是第四次提交,那我们可以退回到第二次提交也就是备注信息是second upload的备注的那一行,复制其索引值接着进行回溯
    git reset --hard 89333c3
    在这里插入图片描述
    在这里插入图片描述

  • 提示说HEAD已经在second upload处,我们可以验证一下是否正确,使用cat test.txt阅读文档
    ***wow,结果不正是我们第二次修改之后文档的信息嘛!***此刻我们已经做到了版本的回溯!
    如果你在查看版本你会有别的发现
    在这里插入图片描述
    系统会告诉你你move to第二次版本的索引!在git中所有的操作都会被记录,且不会存在记录被覆盖的情况

  • 这时候又有人想说那我相回到最后一次修改的地方也就是fourth提交的地方怎么办,那我们可以git reset --hard [fourth索引值]即可!
    在这里插入图片描述

bingo!

这便是部分基础操作,其余的之后再进行详解

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

FreeRTOS学习(一)

裸机与RTOS对比 裸机:又称为前后台系统,前台系统指的是中断服务函数,后台系统指的大循环,即应用程序。 实时性差:(应用程序轮流执行)delay:空等待,CPU不执行其它代码结…

【分享】太阳能电池性能测试指标,太阳能电池IV测试软件系统

在现代社会,随着能源需求的不断增加,太阳能电池的应用越来越广泛。太阳能电池是一种利用太阳光能量将化学能转换为电能的半导体材料,它可以将太阳光中的光能直接转换成电能,因此具有广泛的应用前景。本篇文章纳米软件小编为大家分…

JAVAWeb01-BS架构简述、HTML

1. B/S 软件开发架构简述 1.1 Java Web 技术体系图 1.2 B/S 软件开发架构简述 B/S架构 B/S框架,意思是前端(Browser 浏览器)和服务器端(Server)组成的系统的框架结构。B/S架构也可理解为web架构,包含前端、后端、数据库三大组成部分。示意图 &#xf…

学校的地下网站(学校的地下网站1080P高清)

这个问题本身就提得有问题,为什么这么说,这是因为YouTube本身就不是一个视频网站或者说YouTube不是一个传统的视频网站!!! YouTube能够一家独大,可不仅仅是因为有了Google这个亲爹,还有一点&…

ROS实践12 自定义源文件并调用

文章目录运行环境:思路:原理:1.1 头文件编写1.2 编写源文件1.3 编写可执行文件1.4 🏯配置文件🏯1.5 编译运行运行环境: ubuntu20.04 noetic 宏基暗影骑士笔记本 思路: 上一期:类和…

Serverless MQTT 服务即将正式上线、新增 2 个平台安装包

3 月,EMQX 开源版发布了 v5.0.19、v5.0.20 以及 v5.0.21 三个版本,提供 Rocky Linux 9 以及 MacOS 12 Intel 平台安装包。企业版发布了 v4.4.15 以及 v4.4.16 版本,提供了 Apache IoTDB 支持、HStreamDB 最新版本的适配、MongoDB 6.0 支持等多…

Python SMTP发送邮件和线程

文章目录一、Python SMTP发送邮件二、Python3 多线程总结一、Python SMTP发送邮件 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。 python的smtplib提供…

DevExpress WinForms电子表格控件,让应用更快拥有现代办公体验!

DevExpress WinForm Spreadsheet组件能读写XLSx、XLS、CSV、TXT文件、打印并导出为PDF等,为终端用户提供了当今流行的办公UI体验! PS:DevExpress WinForm拥有180组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。…

QT笔记——QuaZIP压缩文件夹

需求:解压缩包文件 开发环境:win10 vs2019 qt5.14.2 开源地址:QuaZIP下载地址 第一步: 用vs 打开“quazip.sln” 可能解决方案也没有出来,我们可以在 菜单栏 视图-》解决方案资源管理器 我们发现资源管理器也加载失…

若依Linux环境部署

若依Linux环境部署1.若依项目2.后端3.Linux环境配置4.环境部署附录1.若依项目 若依官网若依文档前后端分离代码 2.后端 整体项目结构 自己创建好数据库,并在如下地方修改代码 日志路径也需要修改 数据库建表语句 同时redis也要启动并配置好 后端启动 3.Li…

导数的四则运算

导数的四则运算简单函数复杂函数简单函数 我们举例14个基本初等函数的函数导数。 函数原函数导函数常函数(即常数)yCyCyC(C为常数)y′0y0y′0指数函数yax、yexya^x、ye^xyax、yexy′axlna、y′exya^xlna、ye^xy′axlna、y′ex幂…

产品经理考个PMP有多大作用吗?

现在基本上做产品的会有一个PMP证件,从结果导向来说,不对口不会有这么大范围的人来考,但是需要因地制宜,在公司内部里,标准程序并不流畅,产品和项目并不规范,关系错综复杂。 而产品经理的职能又…

走进小程序【五】微信小程序架构之【逻辑层】详解

文章目录🌟前言🌟小程序架构🌟逻辑层 App Service🌟注册小程序🌟注册页面🌟使用 Page 构造器注册页面🌟在页面中使用 behaviors🌟使用 Component 构造器构造页面🌟页面生…

vs中的错误集合

记录在vs 中遇到的 各种错误 1:project.vcxproj.filters 文件出现了异常,发现了以前的解决方案下的筛选器竟然没有了 原因:合并svn的时候 .vcxproj.filters 文件出现了 合并错误(检查该文件里面是否有不一样的) 解决办法:解决 该文…

Android 手机自动化测试工具有哪几种?

一、Android手机自动化测试工具,常用的有这7中: 1、首推Appium: 推荐理由:功能非常强大的移动端自动化测试框架,还免费 下载链接:Appium: Mobile App Automation Made Awesome. Appium是一种被广泛使用的…

C++ 类与对象part3(static成员、匿名对象、友元、内部类、编译器的优化)

目录 static成员 匿名对象(一次性、临时使用...) 友元 友元函数 友元类 内部类 拷贝对象时的一些编译器优化 static成员 面试题: 对于一个自定义的对象来说,不是调用构造函数就是调用拷贝构造函数,所以我们通常…

创维跨界脑洞大 XR+汽车=睡眠?

4月1日,造车新势力的3月交付/销售成绩单出来了,比亚迪、广汽埃安分别以207080辆和40016辆分列冠亚军,“蔚小理”仍以过万辆或近万辆处于Top10。品牌名单里最突兀的新势力是创维汽车,以1282辆位列第15,上个月的数字是14…

STM32 FSMC接口驱动4.3寸TFT LCD屏

STM32 FSMC接口驱动4.3寸TFT LCD屏 STM32的FSMC接口是并行总线接口,可以用于驱动存储芯片如FLASH/SRAM等,也可以用于驱动并口LCD屏。 这里以STM32F103VET6开发板连接4.3寸TFT LCD屏,将正点原子的参考代码,移植到STM32CUBEIDE开发…

SpringBoot操作Redis

Redis 1、 添加redis依赖 spring Boot 提供了对 Redis 集成的组件包:spring-boot-starter-data-redis,它依赖于 spring-data-redis 和 lettuce 。 另外,这里还有两个小细节: Spring Boot 1.x 时代,spring-data-red…

【Redis】Redis 主从复制 + 读写分离

Redis 主从复制 读写分离1. Redis 主从复制 读写分离介绍1.1 从数据持久化到服务高可用1.2 主从复制1.3 如何保证主从数据一致性?1.4 为何采用读写分离模式?2. 一主两从环境准备2.1 配置文件2.2 启动 Redis3. 主从复制原理3.1 全量同步3.1.1 建立连接3…
最新文章