【Tools】git提示“warning: LF will be replaced by CRLF”的解决办法
原文鏈接:https://blog.csdn.net/u012757419/article/details/105614028
一、發(fā)現(xiàn)問題
windows平臺(tái)下使用git add,git deploy 文件時(shí)經(jīng)常出現(xiàn)“warning: LF will be replaced by CRLF” 的提示。
網(wǎng)上很多解決辦法提到:
設(shè)置core.autocrlf=false,windows也用LF換行。
二、分析問題
格式化與多余的空白字符,特別是在跨平臺(tái)情況下,有時(shí)候是一個(gè)令人發(fā)指的問題。由于編輯器的不同或者文件行尾的換行符在 Windows 下被替換了,一些細(xì)微的空格變化會(huì)不經(jīng)意地混入提交,造成麻煩。雖然這是小問題,但它會(huì)極大地?cái)_亂跨平臺(tái)協(xié)作。
其實(shí),這是因?yàn)樵谖谋咎幚碇?#xff0c;CR(CarriageReturn),LF(LineFeed),CR/LF是不同操作系統(tǒng)上使用的換行符,具體如下:
換行符‘\n’和回車符‘\r’
- 回車符就是回到一行的開頭,用符號(hào)r表示,十進(jìn)制ASCII代碼是13,十六進(jìn)制代碼為0x0D,回車(return);
- 換行符就是另起一行,用n符號(hào)表示,ASCII代碼是10,十六制為0x0A, 換行(newline)。
所以我們平時(shí)編寫文件的回車符應(yīng)該確切來(lái)說叫做回車換行符。
應(yīng)用情況
- Dos和Windows平臺(tái): 使用回車(CR)和換行(LF)兩個(gè)字符來(lái)結(jié)束一行,回車+換行(CR+LF),即“\r\n”;
- Mac 和 Linux平臺(tái):只使用換行(LF)一個(gè)字符來(lái)結(jié)束一行,即“\n”;
- 最早Mac每行結(jié)尾是回車CR 即'\r',后mac os x 也投奔了 unix。
許多 Windows 上的編輯器會(huì)悄悄把行尾的換行(LF)字符轉(zhuǎn)換成回車(CR)和換行(LF),或在用戶按下 Enter 鍵時(shí),插入回車(CR)和換行(LF)兩個(gè)字符。
影響:
- 一個(gè)直接后果是,Unix/Mac系統(tǒng)下的文件在Windows里打開的話,所有文字會(huì)變成一行;
- 而Windows里的文件在Unix/Mac下打開的話,在每行的結(jié)尾可能會(huì)多出一個(gè)^M符號(hào)。
- Linux保存的文件在windows上用記事本看的話會(huì)出現(xiàn)黑點(diǎn)。
這些問題都可以通過一定方式進(jìn)行轉(zhuǎn)換統(tǒng)一,例如,在linux下,命令unix2dos 是把linux文件格式轉(zhuǎn)換成windows文件格式,命令dos2unix 是把windows格式轉(zhuǎn)換成linux文件格式。
三、解決問題:
情況一:
Git 可以在你提交時(shí)自動(dòng)地把回車(CR)和換行(LF)轉(zhuǎn)換成換行(LF),而在檢出代碼時(shí)把換行(LF)轉(zhuǎn)換成回車(CR)和換行(LF)。 你可以用?git config --global core.autocrlf true 來(lái)打開此項(xiàng)功能。 如果是在 Windows 系統(tǒng)上,把它設(shè)置成 true,這樣在檢出代碼時(shí),換行會(huì)被轉(zhuǎn)換成回車和換行:
#提交時(shí)轉(zhuǎn)換為L(zhǎng)F,檢出時(shí)轉(zhuǎn)換為CRLF git config --global core.autocrlf true情況二:
如果使用以換行(LF)作為行結(jié)束符的 Linux 或 Mac,你不需要 Git 在檢出文件時(shí)進(jìn)行自動(dòng)的轉(zhuǎn)換。然而當(dāng)一個(gè)以回車(CR)和換行(LF)作為行結(jié)束符的文件不小心被引入時(shí),你肯定想讓 Git 修正。 所以,你可以把 core.autocrlf 設(shè)置成 input 來(lái)告訴 Git 在提交時(shí)把回車和換行轉(zhuǎn)換成換行,檢出時(shí)不轉(zhuǎn)換:(這樣在 Windows 上的檢出文件中會(huì)保留回車和換行,而在 Mac 和 Linux 上,以及版本庫(kù)中會(huì)保留換行。)
#提交時(shí)轉(zhuǎn)換為L(zhǎng)F,檢出時(shí)不轉(zhuǎn)換 git config --global core.autocrlf input情況三:
如果你是 Windows 程序員,且正在開發(fā)僅運(yùn)行在 Windows 上的項(xiàng)目,可以設(shè)置 false 取消此功能,把回車保留在版本庫(kù)中:
#提交檢出均不轉(zhuǎn)換 git config --global core.autocrlf false你也可以在文件提交時(shí)進(jìn)行safecrlf檢查
#拒絕提交包含混合換行符的文件 git config --global core.safecrlf true #允許提交包含混合換行符的文件 git config --global core.safecrlf false #提交包含混合換行符的文件時(shí)給出警告 git config --global core.safecrlf warn通俗解釋
- git 的 Windows 客戶端基本都會(huì)默認(rèn)設(shè)置 core.autocrlf=true,設(shè)置core.autocrlf=true, 只要保持工作區(qū)都是純 CRLF 文件,編輯器用 CRLF 換行,就不會(huì)出現(xiàn)警告了;
- Linux 最好不要設(shè)置 core.autocrlf,因?yàn)檫@個(gè)配置算是為 Windows 平臺(tái)定制;
- Windows 上設(shè)置 core.autocrlf=false,倉(cāng)庫(kù)里也沒有配置 .gitattributes,很容易引入 CRLF 或者混合換行符(Mixed Line Endings,一個(gè)文件里既有 LF 又有CRLF)到版本庫(kù),這樣就可能產(chǎn)生各種奇怪的問題。
總結(jié)
以上是生活随笔為你收集整理的【Tools】git提示“warning: LF will be replaced by CRLF”的解决办法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【自动驾驶】27.相机畸变_相机内参标定
- 下一篇: 【Linux】33. shell脚本 递