CRLF与LF解析


window和mac的同学合作开发项目,会出现git提交/拉取时换行符不一致导致,提示 "the text is identical, but the files do not match, newlines”等字样,会出现很多文件发生更改,下面说说换行符引起的这个问题.

CRLF

Carriage-Return Line-Feed的缩写,回车换行的意思

  • CR:Carriage Return,对应ASCII 13中转义字符\r,表示回车
  • LF:Linefeed,对应ASCII 10中转义字符\n,表示换行
  • CRLF:Carriage Return & Linefeed,\r\n,表示回车并换行

(ASCII码表里也有用newline, nl表示换行的),据传说,CR、LF最原始的还要追踪到最早到机械打字机时代,CR回到同一行的纸张最左侧的意思,LF代表换一行,将纸张上一一行,两个组合可不就是换行.

 

windnow unix mac等平台换行符不同: 

 

 

 

可以通过git全局设置修改使用的换行符问题,来支持跨平台合作开发项目(window和mac):

1> AutoCRLF

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

git config --global core.autocrlf true   

 

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

git config --global core.autocrlf input   

 

#提交检出均不转换

git config --global core.autocrlf false

 

2>SafeCRLF

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

git config --global core.safecrlf true   

 

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

git config --global core.safecrlf false   

 

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

git config --global core.safecrlf warn


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM