git add 撤销_更科学地管理你的项目,Git 简明教程(二)

修改文件内容

上回说到,我们已经成功创建并提交了一个 README.md 文件到 FirstGit 版本库中

1、修改文件

现在我们更改 README.md 内容

66369f9321baf04123bf4f02465eab96.png

2、查看版本库状态

  • 该文件夹内右键运行 Git Bash Here
  • 执行命令 git status

Git 提示我们的改动还没有 commit,并且它给出了建议,我们可以通过 git add 来提交修改,也可以使用 git restore 来撤销修改

94c49a552788e1185c5b0707e160f423.png

3、查看修改

  • 该文件夹内右键运行 Git Bash Here
  • 执行命令 git diff

Git 会向我们展示我们的修改

f8e662f55d106a12ccc344d62115ed16.png

4、提交修改

  • 执行命令 git add .
  • 执行命令 git status

我们执行 add 之后可以检查一下状态,Git 提示我们修改还没有 commit,但是现在我们的修改已经在暂存区了,Git 提示我们可以使用 git restore --staged 将修改从暂存区撤回

ee5930826357a76e25e52ad50d9e6412.png
  • 执行命令 git commit -m "注释"
  • 执行命令 git status

Git 会提示我们做了哪些改动,commit 之后查看状态可以发现我们的已经没什么可以 commit 了,工作树已经干净了

d45ceb6479951543d3ef7795742b332f.png

版本回退

1、查看历史记录

Git 最大的作用就是管理我们项目的版本,那么现在我想了解我的项目从建立到现在发生了哪些变化,我们可以使用 git log 来查看历史记录

41859c081274aa8ffc3d733b974f8c3e.png

我们也可以使用 git log --pretty=oneline 查看更简洁的历史记录

dc30798dca542cba82a611f41150be02.png

对了,像 712eb00******* 这种是 Git 的版本号 (commit id)

2、回退到上一个版本

通过查看历史记录,我们可以清楚的知道当前的上一个版本是提交我的改动 ,我们可以使用 git reset HEAD^ 进行回退

HEAD^ 表示上一个版本,HEAD^^ 表示上两个版本,上上上 x N 个版本就是 HEAD~N,比如 HEAD~10 就是上 10 个版本

我们还可以使用 git reset --hard HEAD^ 以便了解回退到了哪个版本

3906a1d40811afe16c940e38fbccb1bb.png

3、查看当前版本内容

使用 cat 命令

d20683671b96e13a74f6fbeb164e0ee2.png

前进到未来版本

此时我们如果向前进到之前修改后但是已经被我们撤销的版本(有点绕,用心理解一下),这个时候就需要用到 commit id ,上一个版本的 commit id3b1404f*********commit id 不用写全,Git 能自动匹配

33b042719a719c4716ad92a6a06294ad.png

Git 真的是很棒!可是如果我们不记得之前的版本号怎么办呢?

git reflog 就是一个可以帮助你查看版本变化的命令

8eef96d5a71da610e911859922b2103b.png

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

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

相关文章

Eclipse中Copy Qualified Name复制类全名解决办法

原文链接:http://www.cnblogs.com/zyh1994/p/6393550.html ----------------------------------------------------------------------------------------------- Eclipse中 用Copy Qualified Name复制类全名时 总是这样的/struts1/src/me/edu/HelloAction.java很不…

c 连接mysql错误信息_使用C语言访问MySQL数据 —— 连接和错误处理

2011-05-09 wcdj可以通过许多不同的编程语言来访问MySQL,例如,C,C,Java,Perl,Python,Tcl,PHP等。本文主要总结使用C语言接口如何访问MySQL数据。(一) 连接例程(二) 错误处理(一) 连接…

eclipse编写wordcount提交spark运行

采用集成了scala的eclipse编写代码 代码: package wordcountimport org.apache.spark.SparkConf import org.apache.spark.SparkContextobject WordCount {def main(args: Array[String]): Unit {//非常重要,是通向Spark集群的入口val confnew SparkCon…

gitlab 删除分支_如何删除gitlab上默认受保护的master主分支

今天开发在检查代码的时候,发现master分支有问题,现在准备删除此主分支,并且重新提交正确的代码,不过在删除时发现,master分支不能被删除。ps:主分支一般都是线上分支,需要开发确认后并且做好备…

rsync服务扩展应用

rsync服务扩展应用① 守护进程多模块功能配置第一步:修改配置文件 注:可以再vim中输入:20,22copy22,表示复制20到22行到22行之后 vim /etc/rsyncd.conf[backup01]comment "backup dir by oldboy"path /backup[backup0…

NodeJs 安装

进入官网下载,zip 安装包 https://nodejs.org/en/download/ 解压 配置环境变量到安装目录 cmd 测试 node -v npm -v

SSH秘钥登录服务器

一、查看本机 ssh 公钥,生成公钥 1.通过命令窗口 a. 打开你的 git bash 窗口 b. 进入 .ssh 目录:cd ~/.ssh c. 找到 id_rsa.pub 文件:ls d. 查看公钥:cat id_rsa.pub 或者 vim id_rsa.pub git–查看本机 ssh 公钥&#xff0c…

mysql存入mtr数据_mysql mtr写入数据

selenium 打开浏览器import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.WebE ...Win8.1安装Visual Studio 2015提示需要KB2919355http://www.microsoft.com/zh-cn/download/details.aspx?id42335 安装说明: 1.若要…

diff git 代码实现_Git 自救指南:这些坑你都跳得出吗?

每天都会写架构师文章,Java技术文章天天更新,感兴趣的点个关注再走呗!Git 虽然因其分布式管理方式,不完全依赖网络,良好的分支策略,容易部署等优点,已经成为最受欢迎的源代码管理方式。但是一分…

HDU 4812 D Tree

HDU 4812 思路&#xff1a; 点分治 先预处理好1e6 3以内到逆元 然后用map 映射以分治点为起点的链的值a 成他的下标 u 然后暴力跑出以分治点儿子为起点的链的值b&#xff0c;然后在map里查找inv[b]*k 代码&#xff1a; #include<bits/stdc.h> using namespace std; #d…

Angular CLI 安装

安装Angular 官网的教程&#xff0c;因为国内网络环境原因&#xff0c;访问不了服务器&#xff0c;导致安装失败。 1、先安装NodeJs 安装教程&#xff1a;http://blog.csdn.net/zengmingen/article/details/72650484 2、通过NodeJs中的模块npm 命令行安装 CLI 2.1、设置npm的…

go 写文件_「go」 项目多个文件编程

golang 学习的时候很多sample 讲的都是一个文件的go 文件怎么写&#xff0c;但是现实中不可能所有的实现都写到一个文件里面&#xff0c;按照功能的不同&#xff0c;要么拆分成不同的文件&#xff0c;要么拆分成不同的文件。下面有些个人的经验分享下&#xff0c;如果有问题请指…

CycleGAN 各种变变变

转载自 简单介绍了一下GAN和DCGAN的原理。以及如何使用Tensorflow做一个简单的生成图片的demo。 Ian Goodfellow对GAN一系列工作总结的ppt&#xff0c;确实精彩&#xff0c;推荐&#xff1a;独家 | GAN之父NIPS 2016演讲现场直击&#xff1a;全方位解读生成对抗网络的原理及未来…

pycharm与webstorm 2017 激活破解

原有的方式已经失效&#xff0c;见下面博文&#xff1a; https://blog.csdn.net/justszh/article/details/81484802

mysql blob 比较_与MSSQL对比学习MYSQL的心得(四)--BLOB数据类型

MYSQL里的BLOB数据类型BLOB是一个二进制大对象&#xff0c;用来存储可变数量的数据。BLOB类型分为4种&#xff1a;TinyBlob、Blob、MediumBlob、LongBlob&#xff0c;这几个类型之间的唯一区别是在存储文件的最大大小上不同。MySQL的四种BLOB类型 类型 大小(单位&#xff1…

Webstorm常用快捷键

webstrom 使用 eclipse快键键 File--settings keymap 选择 eclipse 原文链接&#xff1a;http://www.cnblogs.com/yeminglong/p/5995421.html ------------------以下是webstrom默认的----------------------------------- Ctrl/ 或 CtrlShift/ 注释&#xff08;// 或者/…

VirtualBox 上安装Debian 后分辨率设置

VirtualBox 上安装Debian 后分辨率设置 首先要配置source.list打开终端&#xff0c; su 切换成root用户&#xff0c; cd /etc/apt 然后编辑source.list rootdebian:/etc/apt# vi source.list 注释deb cdrom:行&#xff0c;加以下源 deb http://deb.debian.org/debian stretc…

疯狂的程序员_程序员的乐趣是什么?

作者&#xff1a;Java3y我是一个程序员&#xff0c;外行人都以为我是修电脑的&#xff0c;我笑了笑&#xff0c;随意ctrl cctrl v了一把&#xff0c;想象着你们因为我的文章而开心不止&#xff0c;我感到充实而欣慰。想象着你们给我拼命点赞的样子&#xff0c;是多么的滑稽&…

template多行编写的方式

模板是包在 ECMAScript 2015 反引号 () 中的一个多行字符串。 反引号 () — 注意&#xff0c;不是单引号 () — 允许把一个字符串写在多行上&#xff0c; 使 HTML 模板更容易阅读。 反引号&#xff1a;键盘数字键1 旁边的&#xff0c;ESC键下面的键 如果单引号 Component({sel…

sqllite事务和MySQL事务_Android学习---SQLite数据库的增删改查和事务(transaction)调用...

上一篇文章中介绍了手工拼写sql语句进行数据库的CRUD操作,本文将介绍调用sqlite内置的方法实现CRUD操作,其实质也是通过拼写sql语句.首先,创建一个新的android项目:其次,查看代码实现增删查改:1.创建DB工具类MyDBHelper.java(创建数据库的操作)packagecom.amos.android_db;impo…