文件一模一样但是合并时提示有修改
今天合并代码时有个文件一模一样,但是提示有修改。
覆盖代码,下载文件直接替换,执行git config core.filemode false都没用。
编码格式看也是跟别的文件一模一样都是utf-8,直到看见有人说换行符的问题,我就试了一下,如果好了。
原因:
不同操作系统使用的换行符是不一样的。Unix/Linux使用的是LF,Mac后期也采用了LF,但Windows一直使用CRLF【回车(CR, ASCII 13, \r) 换行(LF, ASCII 10, \n)】作为换行符。
而git入库的代码采用的是LF格式,它考虑到了跨平台协作的场景,提供了“换行符自动转换”的功能:如果在Windows下安装git,在拉取文件时,会自动将LF换行符替换为CRLF;
在提交时,又会将CRLF转回LF。但是这个转换是有问题的:有时提交时,CRLF转回LF可能会不工作,尤其是文件中出现中文字符后有换行符时。
设置方法:vscode在编码格式后面(上),IDEA在编码前面(下)。