Git从零开始(二)
前面提交了一个test1.txt文件,接下来看看这个文件接下来的命运。
一、继续修改并提交
在test1.txt中修改后,
git status 查看git的状态,

会提示我们文件test1.txt被修改了,但还没有提交。但到底修改了什么呢?接着往下看,
git diff test1.txt 查看刚刚修改的内容,

会提示add a file,并且还知道添加了 i want some drink。既然文件被修改了,就需要重新添加并提交。
执行 git add test1.txt,然后再 git status 看看git现在的状态

提示修改了的test1.txt将要被提交,执行 git commit -m "i want some drink",再看git状态

提示没有要提交的文件,bingo。
就这样修改文件后,git add test1.txt 添加文件,然后git commit -m "note" 提交文件。
二、版本回退及恢复
1、版本回退
先用 git log 命令查看从近到远的所有版本,后面可加参数 --pretty=oneline

显示现在有两个版本,前面的一长串是版本号,第一条有个标记 HEAD -> master 是指当前版本。
现在想回退到上个版本,
第一种: git reset --hard HEAD^ ,以此类推返回上上个版本就是 HEAD^^
第二种: git reset --hard 31e6184 ,最后的版本号只要前几位就行了

执行命令后提示当前版本是 31e6184,打开文件发现已经变成上个版本的内容。
2、版本恢复
当我们再想回到最新版本时,就必须知道最新版本的版本号,Git提供了一个命令 git reflog,看一看到每次的操作记录,最前面会有版本号

现在再执行 git reset --hard c64de46 ,就回到当前版本啦。

打开文件再看时,已经是最后修改后的内容了。
三、撤销修改
1、把文件改乱了想撤销, git checkout -- test1.txt
2、文件改乱了并已经执行了add,执行 git reset HEAD test1.txt 就回到上面那种状态,然后再执行 git checkout -- test1.txt
3、文件改乱了且已经commit,就只能回退到上个版本了。注意:如果推送到远程服务器就没救了!
四、删除文件
rm test1.txt ,执行完这个命令后,其实版本库的文件还存在,
如果确定删除,则执行 git rm test1.txt ,然后执行 git commit -m "delete test1"
如果发现删错了,则执行 git checkout -- test1.txt,相当于用版本库中的文件替换了工作区的文件
五、git对文件的基本操作就完了,但是到底怎么用到团队中呢?下面还有。
Git从零开始(二)的更多相关文章
- Git 笔记二-Git安装与初始配置
git 笔记二-Git安装与初始配置 Git的安装 由于我日常生活和工作基本上都是在Windows上,因此此处只说windows上的安装.Windows上的安装和其他程序一样,只需要到http://g ...
- 版本控制git之二 分支 切换分支 创建分支 合并 删除
版本控制git之二 分支 有人把 Git 的分支模型称为它的`‘必杀技特性’',也正因为这一特性,使得 Git 从众多版本控制系统中脱颖而出. 为何 Git 的分支模型如此出众呢? Git 处 ...
- Git从零开始怎么学?
最近,公司项目代码版本库管理,全部从svn 迁移到Git 最近了解了一段时间 近期会把整个Git使用过程陆续分享 如何从零开始使用Git
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)
一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)篇 二.本篇目标: l 说说关于cocos2dx手机分辨率适配 l 对前一篇完成的塔防游戏原型进 ...
- Git(二)Git几个区的关系与Git和GitHub的关联
前言 前面只是大概的介绍了一点基础的东西,接下来会更加深入的去了解一下Git. 一.Git的工作区.暂存区和版本库之间的区别和联系 1)工作区 在PC中能看得到的创建的一个管理仓库的目录.比如目录下G ...
- 【Git学习二】深入了解git checkout命令
检出命令(git checkout)是Git最常用的命令之一,同时也是一个很危险的命令,因为这条命令会重写工作区.检出命令的用法如下: 用法一:git checkout[-q][<commit& ...
- Git从零开始(三)
一.远程仓库管理 1.将本地内容推送到远程库 先关联远程库,执行命令: git remote add origin https://github.com/Hollydan/gitstore.git ( ...
- Git从零开始(一)
一.首先windows安装git客户端 官网下载地址:https://git-for-windows.github.io/,这里下载会很慢,我试了好几次都失败了. 百度网盘资源: https://pa ...
- Git(二)使用git管理文件版本(TortoiseGit )
一.创建版本库 什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改.删除,Git都能跟踪,以便任何时刻都 ...
随机推荐
- DataGuard之Apply Services(redo应用和SQL应用)
应用服务 Apply Services 根据oracle官方文档整理 http://docs.oracle.com/cd/E11882_01/server.112/e25608/log_apply.h ...
- scrapy的request的meta参数是什么意思?
作者:乌尔班链接:https://www.zhihu.com/question/54773510/answer/146971644来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注 ...
- mysql insert插入的3种方法
测试表student的字段 1.插入一条数据 INSERT INTO student(sid,sname,sage,ssex) VALUES(1,"wangdali",18,0); ...
- js 对于jquery each 多层循环的问题和原生js多层循环问题
一.在jquery中,我们使用循环的时候,提供两种方式:jquery.each 和(循环体).each 两种方式不是同. 对于return 在作用这两个的函数的时候需要注意: 首先我们需要知道我们的 ...
- JAVA框架 Spring 和Mybatis整合(动态代理)
一.使用传统方式的dao的书写方式,不建议.目前采用的是动态代理的方式交给mybatis进行处理. 首先回顾下动态代理要求: 1)子配置文件的中,namespace需要是接口的全路径,id是接口的方法 ...
- CentOS中配置CDH版本的ZooKeeper
三台CentOS:Host0,Host1,Host2 在三台中分别安装zookeeper-server yum install zookeeper-server -y 修改zookeeper的配置文件 ...
- tarjan 求割点
在无向连通图中,如果将其中一个点以及所连的所有边都删掉,图就不再连通的话,那么这个点就叫做割点 首先将所有的点分为:1.环中点 2.不成环的单点割点一般出现的情况是:如果(处在不同环中/一环一单点/均 ...
- Django Rest Framework源码剖析(五)-----解析器
一.简介 解析器顾名思义就是对请求体进行解析.为什么要有解析器?原因很简单,当后台和前端进行交互的时候数据类型不一定都是表单数据或者json,当然也有其他类型的数据格式,比如xml,所以需要解析这类数 ...
- 网络对抗技术 2017-2018-2 20152515 Exp3 免杀原理与实践
基础问题回答 (1)杀软是如何检测出恶意代码的? 答:分析恶意程序的行为特征,分析其代码流将其性质归类于恶意代码. (2)免杀是做什么? 答:一般是对恶意软件做处理,让它不被杀毒软件所检测,也是渗透测 ...
- log4j配置简要说明
################################################################################ #①配置根Logger,其语法为: # ...