当前位置: 首页 > article >正文

小白的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

相关文章:

  • Serverless架构在实时数据处理中的应用
  • 干货分享之Python爬虫与代理
  • Spring——事务
  • 前端vue 列表中回显并下拉选择修改标签
  • 408笔记合集
  • 微澜:用 OceanBase 搭建基于知识图谱的实时资讯流的应用实践
  • FreeRTOS学习(一)
  • 【分享】太阳能电池性能测试指标,太阳能电池IV测试软件系统
  • JAVAWeb01-BS架构简述、HTML
  • 人脸识别:使用Python和机器学习技术实现
  • 学校的地下网站(学校的地下网站1080P高清)
  • 关于json和xml的知识点总结
  • ROS实践12 自定义源文件并调用
  • Serverless MQTT 服务即将正式上线、新增 2 个平台安装包
  • Python SMTP发送邮件和线程
  • DevExpress WinForms电子表格控件,让应用更快拥有现代办公体验!
  • QT笔记——QuaZIP压缩文件夹
  • 若依Linux环境部署
  • 导数的四则运算
  • 产品经理考个PMP有多大作用吗?
  • 走进小程序【五】微信小程序架构之【逻辑层】详解
  • vs中的错误集合
  • CSDN竞赛第42期题解
  • Android 手机自动化测试工具有哪几种?
  • C++ 类与对象part3(static成员、匿名对象、友元、内部类、编译器的优化)
  • 创维跨界脑洞大 XR+汽车=睡眠?