问题现象:使用git clone命令从库上下载下来的代码,使用VS 2022编译,全文报语法错误,但是代码他其他同事电脑上都能正常编译通过。
期间一度以为是本人电脑上的C++编译环境配置有问题,尝试过卸载掉VS软件重新安装、新增安装VS组件等的方式,最后都无法解决问题,故排除编译环境,问题出现在本地代码本身上。
问题原因:本人在搞安卓开发工作时,为解决代码提交中换行符不统一问题,做过一个配置,目的是将下载的代码中换行符统一转换为LF,配置方式为在.gitconfig中增加如下信息:
[core]
autocrlf = input
因此,此时git clone后checkout出的本地代码,换行符都将为LF,可通过任一IDE打开代码文件,在页面右下角可看到当前代码文件的换行符编码格式。也可以通过notepad++开发,设置显示换行符,就可以看到每行的换行符到底是什么了。
linux文件的换行符是\n字符(LF),而windows文件的换行符是\r\n两个字符(CRLF)。
对于一个跨平台的C++项目,需要保证编译linux平台产物时换行符为LF,编译windows平台产物时换行符切换为CRLF。
而对于windows桌面应用开发而言,C++代码最后的换行符为LF将导致代码被识别为语法错误,无法编译。
参考:git core.autocrlf 跨平台协作编码问题
解决方法:将input修改为true,或者在.gitconfig中直接删掉此配置信息。