git 配置忽略文件(忽略UserInterfaceState.xcuserstate,Breakpoints_v2.xcbkptlist)

时间:2024-01-16 11:46:26

 ios 配置忽略文件.gitignore 文件

之前新建了一个项目,在使用git管理版本的时候没有配置忽略文件 .gitignore 文件,结果导致每次提交的时候都会出现UserInterfaceState.xcuserstate,Breakpoints_v2.xcbkptlist(这个是增添调试断点出现的文件)这两个文件被修改。

一开始还没注意,后来发现每次基本上都会出现,感觉每次看见这两个文件都觉得恶心。虽然不是处女座,但是看着这样也是不爽的。今天闲下来,决定要彻底解决这个问题。好吧,开始百度、谷歌。然后综合了网上的各种大牛写的文章,我自己又总结了一下,希望能帮助到大家。

1:在终端上进入项目,与.git文件并列的地方,执行vim .gitignore 操作(创建一个忽略文件)

vim .gitignore

2:点击i, 进入编辑状态,然后把你要忽略的文件名字输入,如果有多个,记得换行。

  这两个就是一直恶心我的两个文件,我给添加进去。 PS:建议先把这两句话在文本文档改好复制进忽略文件里面

工程名.xcodeproj/project.xcworkspace/xcuserdata/电脑名.xcuserdatad/UserInterfaceState.xcuserstate
工程名.xcodeproj/xcuserdata/电脑名.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist

3:点击Esc,输入:wq,退出编辑状态并保存

4:这个时候你发现,git status时你忽略的文件已经没有存在了。

如果按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),我一般都是删除所有缓存,不用单个删除,然后再提交:

具体在终端操作指令

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

单个文件缓存删除:git rm -r --cached 文件地址  (对比我上面添加进入文件地址)

-------------------------------------------------------我是分割线-------------------------------------------------------------

虽然说上面的已经解决了我的基本需求,但是还是多记录一点,以后肯定用得上

忽略文件每一行保存了一个匹配的规则例如:

# 此为注释 – 将被 Git 忽略

*.a       # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

还有也可以在github上面有一些通用的忽略文件配置,可以参考一下地址:(https://github.com/github/gitignore

参考文章:梧桐树下 » Git忽略规则及.gitignore规则不生效的解决办法