IDEA和GIT关于文件中LF和CRLF问题及解决

 更新时间:2025年09月30日 10:54:06   作者:入门小呆萌  
文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.autocrlf配置(true、input或false)可解决不同场景下的换行符冲突问题

问题描述

项目软件安装shell脚本上git仓库管理,但拉取后,上linux运行报错。


问题思考

根据描述信息可以查看到\r字样,初步判别为换行符导致

1、将脚本文件移动至notepad++中,通过视图—>显示符号—>显示所有符号,一顿操作后,可以看到脚本中一串CRLF的符号


相关名词解释:

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

进而了解到普遍使用的编辑器IDEA因为默认是windows使用场景,所以换行符的默认设置为CRLF;但Shell脚本是在Linux下运行,则需要被替换为LF

在IDEA右下角,除了编码格式以外,还有个Line Separator


废话不多说,为了解决问题,就立马着手将所有的Shell脚本改成了LF

1、一劳永逸,杜绝后续类似问题的出现,可将IDEA的默认配置修改为了LF


*最后的选项,大致是允许IDEA的配置覆盖重写代码的样式设置;可视自身情况选择或取消,与本文影响不大

2、兴致冲冲,将修改后的代码提交后,让测试同事重新验证,emmm对面拉取的还是CRLF。尴尬要犯了

  • 首先怀疑是git未能识别到CRLF和LF这类修改
  • 尝试将文件删除后commit & push再新增LF格式文件后 commit & push失败!!!
  • 在搜了Git LF和CRLF问题后,发现此事儿有点猫腻

git的默认设置中有一个字段:core.autocrlf ,作用就是:

在push的时候会把CRLF转换成LF;pull的时候则会把LF转换成CRLF

原本Git这个自动转换的配置是在做好事儿,但是却坑苦了不懂它的人… …

OK!!!明白了原理,那么解决思路就来了

解决过程

以下命令在Git Bash中执行即可

  • 场景一、代码在window提交,在windows使用(即默认场景)
$ git config --global core.autocrlf true
  • 场景二、代码在windows提交,在Linux或者Mac系统或者Jenkins上专门打包为服务器使用,无需Git在pull时进行自动转换;(即Git在push时把CRLF转换成LF,pull时不转换)
$ git config --global core.autocrlf input
  • 场景三、不想要Git自动转换:
$ git config --global core.autocrlf false

综上:

1、编辑器本身的换行符问题

2、Git在提交和拉取过程的自动转换问题

问题解决!!!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅谈java继承中是否创建父类对象

    浅谈java继承中是否创建父类对象

    下面小编就为大家带来一篇浅谈java继承中是否创建父类对象。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • java数据结构基础:栈

    java数据结构基础:栈

    这篇文章主要介绍了Java的数据解构基础,希望对广大的程序爱好者有所帮助,同时祝大家有一个好成绩,需要的朋友可以参考下,希望能给你带来帮助
    2021-07-07
  • SpringBoot实现防止XSS攻击的示例详解

    SpringBoot实现防止XSS攻击的示例详解

    这篇文章主要为大家详细介绍了SpringBoot如何实现防止XSS攻击,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-03-03
  • Java的内部类总结

    Java的内部类总结

    这篇文章主要为大家介绍了Java的内部类,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • mybatis-plus的sql加载顺序源码解析

    mybatis-plus的sql加载顺序源码解析

    这篇文章主要为大家介绍了mybatis-plus的sql加载顺序源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • java并发无锁多线程单线程示例详解

    java并发无锁多线程单线程示例详解

    这篇文章主要为大家介绍了java并发无锁多线程单线程示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • 基于Java反射的map自动装配JavaBean工具类设计示例代码

    基于Java反射的map自动装配JavaBean工具类设计示例代码

    这篇文章主要给大家介绍了关于基于Java反射的map自动装配JavaBean工具类设计的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用java具有一定的参考学习价值,需要的朋友们下面来一起看看吧
    2018-10-10
  • 深入了解为什么Java中只有值传递?

    深入了解为什么Java中只有值传递?

    这篇文章主要介绍了为什么 Java 中只有值传递?下面我们来简单了解一下吧
    2019-05-05
  • SpringBoot基于自定义注解实现切面编程

    SpringBoot基于自定义注解实现切面编程

    这篇文章主要介绍了SpringBoot基于自定义注解实现切面编程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • Java中字符串与日期转换常见方法总结

    Java中字符串与日期转换常见方法总结

    这篇文章主要给大家介绍了关于Java中字符串与日期转换常见方法的相关资料,在Java编程中经常需要将字符串表示的日期转换为日期对象进行处理,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11

最新评论