前提知识
回车(Carriage Return,CR)与换行(Line Feed,LF)的区别:
概念上:
- 回车,回到当前行的行首,而不会换到下一行,如果接着输出的话,本行以前的内容会被逐一覆盖;
- 换行,换到当前位置的下一行,而不会回到行首
ASCII码上的区别:
- \n 10 换行;
- \r 13 回车CR
重点:
Unix/Linux/Mac系统里,每行结尾只有“<换行>”,即"\n";
Windows系统里面,每行结尾是“<回车><换行>”,即“\r\n”;
所以当我们跨操作系统操作文件时,会产生如下结果:
- Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;
- Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。
举个例子:
$ echo -en '12\n34\r56\n\r78\r\n' > tmp.txt
分别在Windws和Linux中查看此文件可知:
Linux中遇到换行符("\n")会进行回车+换行的操作,回车符反而只会作为控制字符("^M")显示,不发生回车的操作。而windows中要回车符+换行符("\r\n")才会回车+换行,缺少一个控制符或者顺序不对都不能正确的另起一行。
注意点:
在解析文本或其他格式的文件内容时,常常要碰到判定回车换行的地方,这个时候就要注意既要判定"\r\n"又要判定"\n"。
问题描述
windows平台下使用git add,git deploy 文件时经常出现“warning: LF will be replaced by CRLF in 文件” 的提示。
分析问题
Windows平台下,Git所处的环境是Linux,跨平台编进文件时,出现换行符和回车符不统一的情况
解决
情况一:
Git 可以在你提交时自动地把回车(CR)和换行(LF)转换成换行(LF),而在检出代码时把换行(LF)转换成回车(CR)和换行(LF)。 你可以用git config --global core.autocrlf true 来打开此项功能。 如果是在 Windows 系统上,把它设置成 true,这样在检出代码时,换行会被转换成回车和换行:
#提交时转换为LF,检出时转换为CRLF
$ git config --global core.autocrlf true
情况二(一般不会出现):
如果你是 Windows 程序员,且正在开发仅运行在 Windows 上的项目,可以设置 false 取消此功能,把回车保留在版本库中:
#提交检出均不转换
$ git config --global core.autocrlf false
总结:
这个warning不重要,是安全的,所以可以不管!