git在window與linux的換行符問題


1:背景。我win7,后端是win10,使用了TortoiseGit工具。我使用ssh,他使用http。倉庫是在linux,使用gitLab管理

2:問題。倉庫是總監之前建好的。后端把文件add后push,我clone本地后沒有放進編輯器中也沒有做任何的修改,馬上commit,提示所有文件已修改,打開對比了,只是結尾的換行有修改

3:差異。因為之前沒有遇到過這樣的問題,不知從何下手,剛開始以為是編碼問題,百度谷歌后不知所以然,就從編碼到git版本用排除法一一對比,最后發現我們2個人的連接方式不一致。統一了鏈接方式后,問題不存在了,但是這不是解決問題的根本性辦法,一開始以為是這個問題導致的,其實並不是,只是瞎貓碰上死耗子,其實是其中一個終端重新安裝了git使用了一樣的autocrlf

4:總結。這個問題是git在window與linux的換行符問題,autocrlf在window和linux下不一樣。假如不同的終端提交時候使用了不同的換行符,就會出現這個問題

5:解決。

  a、安裝時候,大家的選項大多是默認安裝,所以在autocrlf選項時候,一般也是默認的。

  

  但是,在多人協同開發時候,不同終端不同git的配置不一樣,會導致2的問題

  

 

  安裝時候可以選擇這個,checkout不修改文件換行符,commit不修改文件換行符  

  b、假如已經出現2問題。

    如果你的源文件中是換行符是LF,而autocrlf=true, 此時git add就會遇到 fatal: LF would be replaced by CRLF 的錯誤。有兩個解決辦法:

    1. 將你的源文件中的LF轉為CRLF即可【推薦】

    2. 將autocrlf 設置為 false

 

    如果你的源文件中是換行符是CRLF,而autocrlf=input,  此時git add也會遇到 fatal: CRLF would be replaced by LF 的錯誤。有兩個解決辦法:

    1. 將你源文件中的CRLF轉為LF【推薦】

    2. 將autocrlf 設置為true 或者 false

 

    在Mac上設置 autocrlf = input, 在Windows上設置autocrlf = true(默認值)。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM