Git 之 .gitignore 不生效

引言

有时候太顺了也不是一件好事,有时候不从头自己做一遍你也永远不会发现自己知识的薄弱点

最近,遇到了一件比较有趣的事,事情的经过是这样的:.gitignore已经忽略了build.gradle文件夹下的内容,但是IDEA编译后还是会在控制台追踪这两文件夹下的变化

历程

首先,这是第一次遇到这种情况,第一反应便是:怎么可能?明明已经在.gitignore添加了build.gradle这两文件夹了呀,这绝对不可能,思考了一会儿,我觉得应该是电脑的问题,重启一下可能就好了?

然后,结果当然不是我意料之中那般,在我编译代码后,build.gradle文件夹下的内容还是会被追踪到,就像下图这样生成一大坨完全看不懂、用不到的文件,而更可气的是它还给我追踪到并展示出来,这让我去找需要提交的那一个变更文件显得有些费时(是的,改一个文件,编译生成一坨,然后去找改的那个)

当然,在我还不知道为何会造成这种情况之前,我也不能如此毫无效率的在一大堆文件里去找我需要的那一个文件呀,这样太耗时了,因此这里我自己给自己提供了两种解决方法:

  • 指令提交,add需要提交的那个文件即可,然后其他文件回退
  • 图示化操作,在修改完文件后,先将变动的文件勾选上,再编译,然后其他文件回退

我是比较钟爱图示化操作的,谁叫它方便呐,但是遇到这种情况确实也很令人头大,虽然在上面的方法下,不会造成太大的影响,但是影响美观、影响心情确实是必然的呀~

所以,我还是决定去一探究竟......

解决

首先,需要排除的便是.gitignore文件的问题,因为它已经确确实实的加入了build.gradle

接下来,便是思考为什么会出现.gitignore不生效的原因

但是,在这一步,我先去了解了一下.gitignore生效的时机,就是被加入到.gitignore的文件或文件夹什么时候才不会被追踪、会被忽略?

然后,一查便发现了问题所在:.gitignore文件只能忽略那些还没有纳入版本控制的文件,如果某些文件已经被纳入了版本控制中,则修改.gitignore将不能生效

哦,原来如此,也就是说,build.gradle文件已经被纳入版本控制的文件了,已经被追踪了,所以.gitignore管不到了,那要怎么解决?

反正我知道问题后的第一个想法便是,从头再重新提交,这次要有.gitignore文件,且里面要编写好需要忽略的文件

最后,解法也大差不差,但是没有严重到重新初始化项目重新提交的程度,只需要清空一下暂存区的缓存,然后再提交即可:

bash 复制代码
# 清空本地缓存
git rm -r --cached .

git rm -r --cached .

  • git:这是Git版本控制系统的命令行接口
  • rm:缩写形式,用于删除Git仓库中的文件或目录
  • -r:这个选项代表递归,意味着它将递归地删除目录及其内容
  • --cached:从Git索引中(也称为暂存区)中删除文件或目录不会影响工作目录中的文件
  • .(点号):这是git rm命令的路径参数,.代表当前目录及其所有内容

小结

如果意外地添加了不想由Git跟踪的文件,或者想要取消暂存的一些更改,就可以使用git rm --cached。这个命令将从Git索引中删除文件,但保留它们在工作目录中

强烈建议大家一定要养成在项目初始化时就编写好.gitignore文件的习惯!!!

相关推荐
用什么都重名3 小时前
Git分支合并与远程服务器同步实战:保留关键配置文件
运维·服务器·git
得要找到一束光3 小时前
git详细命令
git·github
2601_961875245 小时前
花生十三公考课程|网课|视频
数据库·windows·git·svn·eclipse·github
EleganceJiaBao8 小时前
【Git】Git reset 完整指南:真正理解 HEAD、暂存区与工作区
git·github·reset
我最爱吃鱼香茄子10 小时前
【保姆级】Git配置用户名和邮箱(全局/局部)解决提交记录不识别、贡献图不亮问题
git·gitee·github·小白教程·git配置·程序员开发工具
weixin_5716674110 小时前
git fork 并建立自己的dev分支 保持与源仓库的联系
git
master33611 小时前
git仓库通过脚本完成多个远程仓库同步
大数据·git·elasticsearch
用什么都重名11 小时前
Git 合并两个无共同历史的分支:从报错到解决全记录
git·gitlab
2601_9618752411 小时前
花生十三资料网盘|百度云|下载
数据库·windows·git·svn·eclipse·github
小香猪668812 小时前
Git 日常操作完全指南:提交、冲突、分支、账户配置一站式教程
git