Git时光机穿梭之删除文件
2024-08-27 00:10:59
在Git中,删除也是一个修改操作,我们实战一下,先添加一个新文件test.txt到Git并且提交:
$ git add test.txt
$ git commit -m "add test.txt"
[master 94cdc44] add test.txt
1 file changed, 1 insertion(+)
create mode 100644 test.txt
一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm
命令删了:
$ rm test.txt
这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status
命令会立刻告诉你哪些文件被删除了:
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add/rm <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# deleted: test.txt
#
no changes added to commit (use "git add" and/or "git commit -a")
现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm
删掉,并且git commit
:
$ git rm test.txt
rm 'test.txt'
$ git commit -m "remove test.txt"
[master d17efd8] remove test.txt
1 file changed, 1 deletion(-)
delete mode 100644 test.txt
现在,文件就从版本库中被删除了。
另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:
$ git checkout -- test.txt
git checkout
其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
小结
命令git rm
用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
最新文章
- titit. 深入理解&#160;内聚(&#160;Cohesion)原理and &#160;attilax大总结
- JDBC的简单使用
- 我的Android第五章
- SQLSERVER2008新增的审核/审计功能
- node 通用的中间件
- Android开发方向
- [__NSCFNumber length]: unrecognized selector sent to instance 0x8b3c310
- linux进程调度函数浅析(基于3.16-rc4)
- Hdu 5568 sequence2 高精度 dp
- Opencv 完美配置攻略 2014 (Win8.1 + Opencv 2.4.8 + VS 2013)上
- Bootstrap基础学习(二)&mdash;表单
- python模块安装报错 :error: command &#39;gcc&#39; failed with exit status 1
- poj1258prim算法
- Docker: 企业级镜像仓库Harbor的使用
- Go语言学习之12 etcd、contex、kafka消费实例、logagent
- python标准库之operator(运算符模块)
- [Python设计模式] 第3~5章 单一职责原则/开放-封闭原则/依赖倒转原则
- javascript总结集合
- Reflector_8.3.0.93_安装文件及破解工具
- Django之模板配置(template)