五种状态间的顺序操作

四个区

    1. 工作区(Working Area)
    1. 暂存区(Stage)
    1. 本地仓库(Local Repository)
    1. 远程仓库(Remote Repository)

五种状态

    1. 未修改(Origin)
    1. 已修改(Modified)&未追踪(Untracked)
    1. 已暂存(Staged)
    1. 已提交(Committed)
    1. 已推送(Pushed)

顺序操作

  • 第零步:工作区与仓库保持一致
  • 第一步:文件增删改,变为已修改状态
  • 第二步:git add ,变为已暂存状态
$ git add --all # 当前项目下的所有更改
$ git add .  # 当前目录下的所有更改
$ git add xx/xx.py xx/xx2.py  # 添加某几个文件
  • 第三步:git commit,变为已提交状态
$ git commit -m"<这里写commit的描述>"
  • 第四步:git push,变为已推送状态
$ git push -u origin master # 第一次需要关联上
$ git push # 之后再推送就不用指明应该推送的远程分支了
$ git branch # 可以查看本地仓库的分支
$ git branch -a # 可以查看本地仓库和本地远程仓库(远程仓库的本地镜像)的所有分支

五种状态间的撤销操作

已修改,但未暂存

$ git diff # 列出所有的修改
$ git diff xx/xx.py xx/xx2.py # 列出某(几)个文件的修改
$ git checkout # 撤销项目下所有的修改
$ git checkout . # 撤销当前文件夹下所有的修改
$ git checkout xx/xx.py xx/xx2.py # 撤销某几个文件的修改
$ git clean -f # untracked状态,撤销新增的文件
$ git clean -df # untracked状态,撤销新增的文件和文件夹# Untracked files:
#  (use "git add <file>..." to include in what will be committed)
#
#   xxx.py

已暂存,未提交

这个时候已经执行过git add,但未执行git commit,但是用git diff已经看不到任何修改。

因为git diff检查的是工作区与暂存区之间的差异。

$ git diff --cached # 这个命令显示暂存区和本地仓库的差异
$ git reset # 暂存区的修改恢复到工作区
$ git reset --soft # 与git reset等价,回到已修改状态,修改的内容仍然在工作区中
$ git reset --hard # 回到未修改状态,清空暂存区和工作区

git reset --hard 操作等价于 git reset 和 git checkout 2步操作

已提交,未推送

执行完commit之后,会在仓库中生成一个版本号(hash值),标志这次提交。之后任何时候,都可以借助这个hash值回退到这次提交。

$ git diff <branch-name1> <branch-name2> # 比较2个分支之间的差异
$ git diff master origin/master # 查看本地仓库与本地远程仓库的差异
$ git reset --hard origin/master # 回退与本地远程仓库一致
$ git reset --hard HEAD^ # 回退到本地仓库上一个版本
$ git reset --hard <hash code> # 回退到任意版本
$ git reset --soft/git reset # 回退且回到已修改状态,修改仍保留在工作区中。

已推送到远程

$ git push -f orgin master # 强制覆盖远程分支
$ git push -f # 如果之前已经用 -u 关联过,则可省略分支名

慎用,一般情况下,本地分支比远程要新,所以可以直接推送到远程,但有时推送到远程后发现有问题,进行了版本回退,旧版本或者分叉版本推送到远程,需要添加 -f参数,表示强制覆盖。

总结

  • 首先,先用git status查看下当前状态。
  • git reset可以作用于本地仓库,用于回退/前进到任意版本,也可以作用于暂存区,用于撤销暂存区修改。有hard和soft2个参数。soft参数可以省略,soft参数表示撤销的修改仍放在工作区中。
  • git checkout用于撤销删除和修改,git clean -df用于撤销新增。
  • git diff可以查看工作区、暂存区、仓库之间的修改和差异,参数不同。

一张图看明白Git的四个区五种状态相关推荐

  1. 一张图看明白UML类图中的6种关系

    在UML类图中,有6种关系,分别是: (1)泛化(Generalization),简单说就是父类和子类的关系,extends/: (2) 实现(Realization),简单说就是接口和实现的关系,i ...

  2. 一张图看明白部标808协议

    4协议内容 41通信方式 协议采用的通信方式应符合JT/T 794中的相关规定,通信协议采用TCP或UDP,平台 作为服务器端,终端作为客户端.当数据通信链路异常时,终端可以采用SMS消息方式进 行通 ...

  3. 一张图看明白云计算架构核心竞争力

    低TCO 计算资源的成本优化和节省 存储资源的成本优化与节省 网络资源的成本优化与节省 维护成本的优化与节省 节能减排等生命周期维护成本的节省 弹性伸缩 管理节点弹性伸缩能力 数据中心资源的弹性伸缩能 ...

  4. 一张图看明白电信云解决方案架构

    NFV(Network Function Virtualization)网络功能虚拟化旨在通过研究标准IT虚拟化技术,是的电信网络设备的功能能够以软件方式运行在符合行业标准的大容量通用的服务器.交换机 ...

  5. 一张图看明白响应式和自适应的区别

    响应式设计(RWD):建立一个网页,通过CSS Media Query,Content - Based Breakpoint等技术来改变网页的大小适应不同分辨率的屏幕 自适应设计(AWD):为不同类别 ...

  6. 一张图看懂自然语言处理技术框架

    一张图看懂自然语言处理技术框架 一.前言 正在针对<人工智能产品经理最佳实践>视频课程第三部分,关键技术篇,进行相关的内容重构,今天整理的部分是自然语言处理技术框架,特地绘制了一张自然语言 ...

  7. 一张图看懂世界石油分布?用Python轻松搞定!(附数据下载)

     CDA数据分析师 出品   [导语]:今天我们教你用Python画出世界石油分布桑基图,Python技术部分可以直接看第四部分. 获取数据: 扫描下方公众号 回复关键字"石油" ...

  8. 一张图看懂世界石油分布?用Python轻松搞定!

     CDA数据分析师 出品   [导语]:今天我们教你用Python画出世界石油分布桑基图,Python技术部分可以直接看第四部分. 作者:Mika 数据:真达   后期:泽龙  设计:一凡   Sho ...

  9. 荣耀v20云计算机,一张图看懂荣耀v20,小米9,iqoo谁值得买(云分析)

    一张图看懂荣耀v20,小米9,iqoo谁值得买(云分析) 2019-03-09 13:22:20 17点赞 5收藏 65评论 本文前言--应该来说全世界手机市场,就数中国的手机市场水最深吧,发布猛如虎 ...

最新文章

  1. 百度编辑器修改,不让它自动替换html标签
  2. ubuntu 运行android sdk 下的工具adb报bash: ./adb: No such file or directory
  3. 本人转行,出售二手.net书籍和源码,书籍3-4折,都是新华书店原版书。
  4. zynqpl端时钟_第十二章 ZYNQ-MIZ702 PS读写PL端BRAM
  5. 如何debug函数_如何使用 pdb 来性感 debug 你的 Python 代码?
  6. 数据结构---队列C语言实现
  7. 深入理解Docker Volume(一)
  8. 工程日志(110316)-机房内电子信息设备电量估算
  9. Laravel 5 的 Simple Captcha 包
  10. Window10下修改User文件夹中的 用户文件夹 名称
  11. LED点阵显示,有关特殊国别(阿拉伯,希伯来,泰文)字符排版和乱码问题解决
  12. 视频处理之浮雕效果【附源码】
  13. laravel 邮件发送
  14. 2022-2028全球重要器官支持系统和医学仿生学行业调研及趋势分析报告
  15. 富通天下(W 笔试)
  16. python实现采样函数_PR Sampling Ⅰ: 蒙特卡洛采样、重要性采样及python实现
  17. selenium 原理应用 - 利用 requests 模拟 selenium 驱动浏览器
  18. 手把手教你开发微信小程序中的插件
  19. 网站劫持有什么样的影响
  20. 英语口语268之每日十句口语

热门文章

  1. python3的socket_python2 与 python3 socket编程的一点小区别
  2. Java基础:常用IO流
  3. sqlitepython导入数据_python从sqlite读取并显示数据的方法
  4. 超级计算机预测降雪,南方九省即将大雪纷飞?超级计算机:可能性增加,但还没有确定...
  5. proe输入数字时成双出现_Proe/Creo步进电机正反转仿真详解
  6. c语言编程获取当前系统时间包含年,月,日,时,分,秒.,C语言获取系统时间的几种方式...
  7. mysql 导出中文乱码_sqoop导出到mysql中文乱码问题总结、utf8、gbk
  8. ensp中ap获取不到ip_对比网络模拟器软件,Cisco Packet Tracer、华为eNSP、H3C Cloud Lab...
  9. python3.8提示pip_Linux下升级安装python3.8并配置pip及yum的教程
  10. pythonloop循环结构_python - tensorflow,tf.while_loop:这两个结构没有相同的嵌套结构 - SO中文参考 - www.soinside.com...