git discard all清空所有未提交、清除文件变更
git discard不是原始命令,但一般的 git 管理工具会提供,怎么用原始 git 命令实现呢?
清空所有未提交文件,忽略 .gitignore 指定的内容(推荐使用)
git clean -df
git checkout .
清空所有未提交文件,无论其是否在 .gitignore 中指定(非常危险)
git clean -dfx
git checkout .
git clean命令用来从你的工作目录中删除所有没有tracked过的文件
git clean -n
是一次clean的演习, 告诉你哪些文件会被删除. 记住他不会真正的删除文件, 只是一个提醒
git clean -f
删除当前目录下所有没有track过的文件. 他不会删除.gitignore文件里面指定的文件夹和文件, 不管这些文件有没有被track过
git clean -f <path>
删除指定路径下的没有被track过的文件
git clean -df
删除当前目录下没有被track过的文件和文件夹
git clean -xf
删除当前目录下所有没有track过的文件. 不管他是否是.gitignore文件里面指定的文件夹和文件
git reset --hard和git clean -f是一对好基友. 结合使用他们能让你的工作目录完全回退到最近一次commit的时候
git clean对于刚编译过的项目也非常有用. 如, 他能轻易删除掉编译后生成的.o和.exe等文件. 这个在打包要发布一个release的时候非常有用
下面的例子要删除所有工作目录下面的修改, 包括新添加的文件. 假设你已经提交了一些快照了, 而且做了一些新的开发
git reset --hard
git clean -df
运行后, 工作目录和缓存区回到最近一次commit时候一摸一样的状态,git status会告诉你这是一个干净的工作目录, 又是一个新的开始了!
总结:
- git clean -n:提示将要清空的内容(不包括.gitignore里指定的内容)
- git clean -f:删除将要清空的内容(不包括.gitignore里指定的内容)
- git clean -df: 和上一个相同,只是显示指定当前目录
- git clean -xfn:提示将要删除的内容(不管是否 .gitignore)
- git clean -xf:删除将要清空的内容(不管是否 .gitignore)
总的来说,这几个参数,可以随意搭配,只要带了 n 则为警告,只要带了 x 则忽略 .gitignore,带了 f 则真正删除(同时带n则f无效),等等。
另外,还有一个没提到,但是很重要的语句:git checkout . 就是清空当前目录所有已经修改的文件,原理是 git 重写工作区从而放弃所有修改(从索引中覆盖现有文件)。
文章作者: 朱丰华
文章链接: https://smart.52dixiaowo.com/blog/post-48.html
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。