在使用git管理文本文件内容版本控制时,发现,只修改了文件的部分内容如几个字或几行字,结果用git gui的“rescan”,整个文件的内容都显示成红色了,这样,就很难看出是修改了哪些内容。
问题的原因:不同操作系统使用的换行符是不一样的
Unix/Linux使用的是LF,Mac后期也采用了LF,但Windows一直使用CRLF【回车(CR, ASCII 13, r) 换行(LF, ASCII 10, n)】作为换行符。而git入库的代码采用的是LF格式,它考虑到了跨平台协作的场景,提供了“换行符自动转换”的功能。
在Windows下使用git,在拉取文件时,会自动将LF换行符替换为CRLF;在提交时,又会将CRLF转回LF。就是这个转换有问题的。
解决方案
1.禁用git自动换行,防止重新拉分支时再度文件自动转码:
git bash命令行进行全局配置:
git config --global core.autocrlf false
git config --global core.filemode false
git config --global core.safecrlf true
2.问题文件修复,可用notepad++或其它可以切换 文本换行符的编辑器,打开有问题的文件,统一切换文件的换行符,再保存,git gui就能正常显示此次变更的内容了
标签:LF,文件,git,一行,修改,内容,换行符 From: https://www.cnblogs.com/mark946/p/17496449.html