`

Git学习系列(三)版本回退和管理文件的修改及删除操作

 
阅读更多

版本回退

前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下:

 

Hello Git
Git is so easy.

 

然后用git status来跟踪该文件的状态:

可以看到hellogit.txt已经被修改过了,到底这次修改的内容与上次的内容有什么不同的,咱们可以使用git diff查看:

当然你也可以查看上次提交的信息,使用git log:

通过前面一章我们知道,该文件还处于工作区,因此我们又可以使用add、commit操作了:

这里笔者偷了个懒,直接用-m表示提交的信息,当然在学习过程中咱可以这样,但实际工作中一般不这么写。

好了,提交完后咱再用git status来跟踪一下(建议多使用git status)状态:

这里依然是:Git告诉咱们当前没有需要提交的修改,而且工作目录是干净的。

下面再学一个命令:git reflog,它主要用来记录你的每一次命令和commit id,这个命令非常有效,也建议大家常用。


可以看到咱提交的id号和提交的message被显示出来了。

加入你现在不想修改了,想回到原来那个版本,该怎么办呢?别急,这一点Git早就帮我们想好了,使用git reset --hard HEAD^

注意:这里HEAD上面^表示回到上一个版本,如果想回到前面第五个版本呢?我们可以用git reset --hard HEAD~5,当然因为我们这里只修改了1次,所以我们最多只能回到前面一个版本。打开hellogit.txt看看,是内容不是Hello Git呢?得意当然如果你又想修改回去,那么咱们还有办法,用git reset --hard commit-id:

注意:这里的e75e865指的是commit id,上面已经说了,这里就不再赘述。

撤销修改:

下面我们再次对helliogit.txt进行修改,内容如下:

 

Hello Git
Git is so easy.
Easily learn the Git.

然后我们用git status跟踪状态:

 

这里Git会告诉你,git checkout -- file可以丢弃工作区的修改:

命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,然后在查看状态:

工作目录有变回”clean“了,查看hellogit.txt内容 cat hellogit.txt

内容又改回来了,这样就完成了一次简单的修改撤销。如果你把文件内容修改为原来添加时的:

 

Hello Git
Git is so easy.
Easily learn the Git.

git add hellogit.txt到了暂存区,咱们还有办法,使用git reset HEAD hellogit.txt来返回到工作区状态:

 

竟然已经回到了工作区,那么咱们就可以向之前那样,使用git checkout -- hellogit.txt了:

好了,一切又回到了,原来的状态。如果你还从暂存区提交到了版本库,还记得上面的版本回退吗?可以回到上一个版本就OK了,不过如果你还将本地的修改推送到远程版本库(后面会讲),那就没有后悔药吃了。

 

删除文件

前面已经说了,在Git中,删除也算一个修改操作。下面咱们先添加一个新文件1.txt到Git并且提交:

这是你如果执行rm 1.txt把1.txt文件删了,那么这个时候,Git知道你删了文件,工作区和版本库就不一致了,我们再用git status跟踪一下:

这是你有两个选择,一是确实要从版本库中删除,使用git rm 1.txt并commit一下:

注意:你删除之后,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。

另一种情况,你觉得你删除了想修改过来,因为版本库中还存在,所以可以很轻松地把误删的文件恢复到原来版本。

可以看到,1.txt有回到工作区了。


总结

今天内容比较多,可能需要点时间慢慢消化,如果有哪里写的不对多需要改进或哪里的地方可以留言,我现在的工作很闲。吐舌头明天开始讲远程仓库。

分享到:
评论

相关推荐

    git - 回退操作.pdf

    #### 三、Git回退操作的基本概念 1. **HEAD**: 指向当前分支的最新提交。 2. **commit**: 一次完整的提交动作,包含了提交的信息以及所涉及的文件列表。 3. **add**: 将文件的更改加入到暂存区,为后续的提交做准备...

    GIT版本控制管理工具操作手册

    6. **重置与回退**:如`git reset`和`git revert`用于撤销变更,理解它们的区别很重要。 7. **解决冲突**:当多人同时修改同一文件时可能会出现冲突,手册会介绍如何识别和解决这些冲突。 8. **标签管理**:`git ...

    git回退及撤销操作md,学习代码

    了解并熟练掌握这些Git回退和撤销操作对于高效开发至关重要。记住,每个操作都可能影响到版本历史,因此在执行时需小心谨慎。通过实践和熟悉这些命令,你可以更好地管理你的代码库,确保团队的协同工作顺畅无阻。

    Git+版本管理+Git学习资料

    - **回退到特定版本**:使用`git reset --hard commitID`可以回退到指定的提交版本。需要注意的是,这将覆盖所有后续的更改,谨慎操作。 - **恢复已删除的commit**:如果找不到commitID,`git reflog`可以帮助找回...

    学习git和gitbash使用的一些详细操作

    - 版本回退:`git reset --hard <commit-id>`命令用来回退到指定的提交状态。`git log`可以查看提交的历史记录,而`git reflog`能够查看分支的移动记录。 - 删除文件:`git rm <file>`命令用于删除工作区中的文件,...

    Git 管理工具和操作文档(msysgit for windows)

    9. **撤销操作**:`git reset`和`git revert`可用于撤销提交或回退到某个状态。 10. **Stash**:`git stash`用于临时保存未提交的更改,以便切换到其他分支或恢复工作环境。 通过学习这个文档,你可以掌握Git的基本...

    git代码版本管理工具学习笔记

    ### Git代码版本管理工具学习笔记 #### Git简介与基本概念 Git是一款分布式版本控制系统,用于追踪计算机文件的变动,并协调由多人共同开发的项目。它能够帮助开发者们管理项目历史,确保每次更改都有迹可循,同时...

    在TwinCAT3中使用Git进行版本管理-整理版 1

    在 TwinCAT3 中使用 Git 进行版本管理,主要包括以下几个部分:Git 的下载和安装、将 TC3 工程中的 PLC 部分添加到本地仓库、使用 Git 进行版本管理、连接远程 GitHub 上传代码。 Git 的下载和安装 ---------------...

    Git学习笔记.pdf

    Git工作流程中通常会涉及到版本库与文件操作,包括创建版本库、添加文件到仓库、查看仓库状态、提交修改、版本回退、撤销修改、删除文件等。创建版本库是在一个文件夹下执行git init命令,该命令会创建一个隐藏的....

    git.docx个人自学笔记

    * Git 可以管理文件的变化,包括添加、删除和修改。 * 文件可以被添加到暂存区,然后提交到版本库。 * 使用 `git add` 命令可以将文件添加到暂存区。 * 使用 `git commit` 命令可以将文件提交到版本库。 四、 Git ...

    git使用基本语言

    已提交的更改可以通过指定版本号或HEAD来回退,例如`git reset --hard HEAD^`回到上一版本,`git reset --hard HEAD~3`回退三个版本。若只想回退某个文件,可以加上文件名。如果想回退到某个特定版本,使用`git ...

    git git git 版本管理工具

    在Git中,你可以轻松地查看历史版本、回退到特定版本、比较不同版本之间的差异,甚至可以合并两个分支的代码。它还支持分支(Branch)和合并(Merge),允许开发者在不同的分支上并行开发,然后将各自的工作整合在...

    Java进阶版本管理工具Git全套视频教程

    6.8 回退至历史版本 6.9 文件删除 6.9.1本地删除与恢复 6.9.2从版本库删除 6.9.3从版本库删除,但是不删除本地 6.10 忽略提交 7. Git 的基本使用02-TortoiseGit 操作本地仓库(分支) 7.1 分支的概念 7.2 为何要使用...

    git完整学习

    - **版本回退**:当文件被错误修改或删除时,可以通过Git命令将文件回退到之前的版本。 - **管理修改**:包括如何查看修改状态、暂存修改、撤销修改以及删除文件等操作。 #### 五、远程仓库 - **生成SSH Key**:...

    crossin-Git基础系列

    `git reset`和`git revert`命令可以帮助你撤销错误的修改或回退到特定版本。 5. 冲突解决: 当两个开发者修改了同一部分代码时,Git会报告冲突。通过编辑器手动解决冲突后,再用`git add`和`git commit`提交解决...

    git版本回退_动力节点Java学院整理

    在这个过程中,readme.txt文件经历了多次修改和提交,并通过git log查看了提交历史,体现了Git版本回退的使用场景和操作步骤。 总的来说,Git版本回退是一个非常重要的功能,它允许开发者在出现错误时可以快速回到...

    版本控制软件-Git学习_V1.0_git版本控制_

    1. **版本管理**:Git的核心功能是版本管理,它能够记录文件和目录的每一次修改,使得开发者可以随时回溯到历史版本,避免误操作带来的损失。 2. **分布式特性**:Git与其他集中式版本控制系统(如SVN)不同,每个...

    Git权威指南 (git学习权威书籍)

    - **git reset**:回退提交,可以撤销已添加到暂存区或已提交的更改。 - **git checkout**:恢复工作目录或暂存区的文件到某一状态。 11. **工作流模型**: - **GitHub Flow**:基于Pull Request的工作流。 - *...

    git本地代码管理指令

    - `git reset --hard HEAD~3`:回退到前三个版本。 - `git reflog`:查看所有提交历史,包括已经被回退的版本。 - `git reset --hard <version>`:直接回退到指定的版本。 - **说明**: - 使用`git log`时,可以...

    git 学习_思维导图_git学习_源码

    Git的主要操作包括初始化仓库(`git init`),克隆远程仓库(`git clone`),添加文件到暂存区(`git add`),提交更改(`git commit`),查看状态(`git status`),以及回退版本(`git reset`等)。此外,分支...

Global site tag (gtag.js) - Google Analytics