很多小伙伴可能会有这种体验:从git上拉取代码后,只修改了一行代码,提交代码时,却发现整个文件都被修改了。不要慌,这是git自动转换换行符导致的问题。

原因

1.不同操作系统使用的换行符是不一样的。

Unix/Linux使用的是LF,Mac后期也采用了LF,但Windows一直使用CRLF【回车(CR, ASCII 13, \r) 换行(LF, ASCII 10, \n)】作为换行符。

2.而git入库的代码采用的是LF格式,它考虑到了跨平台协作的场景,提供了“换行符自动转换”的功能。

3.如果在Windows下安装git,在拉取文件时,会自动将LF换行符替换为CRLF。

4.在提交时,又会将CRLF转回LF。但是这个转换是有问题的:有时提交时,CRLF转回LF可能会不工作,尤其是文件中出现中文字符后有换行符时。

解决方案

1.禁用git的自动换行功能:

在本地路径 C:\ Users\ [用户名] \ .gitconfig 下修改git配置[core],如果没有就直接添加上去:

[core]

autocrlf = false

filemode = false

safecrlf = true

git bash命令行也可以修改,最终也是修改.gitconfig配置文件:

git config --global core.autocrlf false

git config --global core.filemode false

git config --global core.safecrlf true

2.配置IDE开发环境,将它的换行格式指定为LF:

3.配置好了,就ok了,使用命令查看一下:

C:\Users\G\xxxx>git config --list --global

core.ignorecase=false

core.autocrlf=false

core.filemode=false

core.safecrlf=true

user.name=xxxxx

user.email=xxxxxxx

Logo

更多推荐