只修改了一行内容,git却显示整个文件被修改了

发布时间 2023-06-21 15:56:03作者: 我的小苹果

在使用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就能正常显示此次变更的内容了