在各操作系统下,文本文件所使用的换行符是不一样的。UNIX/Linux 使用的是 0x0A(LF),早期的 Mac OS 使用的是0x0D(CR),后来的 OS X 在更换内核后与 UNIX 保持一致了。但 DOS/Windows 一直使用 0x0D0A(CRLF)作为换行符。Git提供了一个“换行符自动转换”功能。这个功能默认处于“自动模式”,当你在签出文件时,它试图将 UNIX 换行符(LF)替换为 Windows 的换行符(CRLF);当你在提交文件时,它又试图将 CRLF 替换为 LF。Git 的“换行符自动转换”功能听起来似乎很智能,因为它试图一方面保持仓库内文件的一致性(UNIX 风格),一方面又保证本地文件的兼容性(Windows 风格)。但是这个功能是有bug的,短期内都不太可能会修正。

在window下开发有一个大坑,就是换行默认是CRLF,也就是回车换行,但是Linux下只有换行LF,这样代码提交后,会出现编译问题,所以最好的办法是在IntelliJ下设置默认为LF。首先我们先介绍CRLF,LF和CR这三种东西,CR是MAC老版本的做法,就是回车,但是后来的MAC系统统一换成LF了,LF是Linux下的做法,就是换行,这个做法比较自然,为什么要回车换行呢,是吧。微软采用的是CRLF,看上去好像是兼容了CR和LF,但是实际完全不是那么回事,就是回车并换行。

第一步:File->Settings…

第二步:Editor->Code Style
可以看到,默认是System-Dependent,这个其实还是很牛叉的,根据系统自动配置,但是你是windows系统,默认是CRLF,服务器是Linux,你就得自己换了。

我们设置成下面这样,保存就好了 :

创建文件时,就能看到默认是LF了

或者直接在idea的terminal根据参数进行设置:

1.Git设置

 

git config –global core.autocrlf false

git config –global core.safecrlf true

含义

AutoCRLF

#提交时转换为LF,检出时转换为CRLF

git config –global core.autocrlf true

 

#提交时转换为LF,检出时不转换

git config –global core.autocrlf input

 

#提交检出均不转换

git config –global core.autocrlf false

SafeCRLF

#拒绝提交包含混合换行符的文件

git config –global core.safecrlf true

 

#允许提交包含混合换行符的文件

git config –global core.safecrlf false

 

#提交包含混合换行符的文件时给出警告

git config –global core.safecrlf warn

2.IDE设置使用UNIX换行符

 

IDEA的设置File -> Settings

Editor -> Code Style

Line separator (for new lines) ,选择:Unix and OS X (\n)

 

对已使用Windows换行符的文件,可以使用Sublime Text打开,

View->Line Endings,选Unix,保存;

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。