一 问题发生

在使用git命令git diff时,内容的末尾出现了“\ No newline at end of file”,即在文件的末尾没有文件换行符。如下图所示:

二 问题分析

  文件的末尾没有文件换行符,似乎没有什么问题。但是仔细思考,就会发现问题所在。文本文件内容的修改是基于刚定位的,也就是说对于某行添加或者删除了若干字符,git无法定位到这些字符的表动。针对此行来说,前后内容变化了,git理解为先删除修改前的此行后添加修改后的此行。

  于是,问题产生了。由于行的末尾没有换行符,如果我们想在新的一行上添加内容,首先要输入换行符。原来没有换行符,现在添加了换行符,那么这一行的内容就发生了改变,就会先删除原来没有换行符的“行”,添加有换行符的行。

举个例子,文本文件内容开始为hello world(没有换行符),然后想在新行上添加内容,输入了换行符。(试验环境:Windows10系统,notepad++编辑器


内容上并不影响,但是不符合逻辑。

因此建议:在编辑文件时(尤其是Windows系统上),在文件末尾的行上手动添加换行符。

三 相关知识

参考链接

Unix历史上有一个所有人类可读的文本文件都以换行符结尾的约定。当时,这避免了在显示或连接文本文件时进行额外的处理,并避免了将文本文件与包含其他类型数据的文件(例如原始二进制数据,这是人类无法读取的)进行不同的处理。

由于这种惯例,那个时代的许多工具都期望换行结束,包括文本编辑器、差异化工具和其他文本处理工具。Mac OS X是在BSD Unix上构建的,Linux是为与Unix兼容而开发的,因此两个操作系统都继承了相同的约定、行为和工具。

Windows并没有开发成与Unix兼容,所以它没有相同的约定,而且大多数Windows软件都会处理得很好,没有后继的换行符。但是,由于Git首先是为Linux开发的,并且许多开源软件都建立在与Unix兼容的系统上,如Linux、Mac OS X、FreeBSD等,因此大多数开源社区及其工具(包括编程语言)继续遵循这些约定。

有一些技术原因在1971年是有意义的,但在这个时代,它主要是传统的,并保持与现有工具的兼容性。

Git No newline at end of file相关推荐

  1. 【错误记录】PyCharm 运行 Python 程序报错 ( PEP 8: W292 no newline at end of file )

    文章目录 一.报错信息 二.解决方案 一.报错信息 PyCharm 运行 Python 程序报错 : PEP 8: W292 no newline at end of file 二.解决方案 在每个 ...

  2. 【报错解决】gcc编译运行c语言程序报警告warning: no newline at end of file

    问题描述 写C语言代码,用gcc进行编译运行.出现警告. warning: no newline at end of file 解决办法 在代码的最后一行加上一个回车.就可以了.没错就是简单. 例如你 ...

  3. linux c之gcc -g file.c -o file提示warning: no newline at end of file

    1 问题 编译c文件的时候,命令如下 gcc -g file.c -o file 错误提示如下 warning: no newline at end of file 2 解决办法 原因:源文件的最后一 ...

  4. c语言文件尾没有newline字符,关于C++:”文件末尾无新行”编译器警告“No newline at end of file”...

    在某些C++编译器中,下面的警告是什么原因? No newline at end of file 为什么在源文件/头文件的末尾应该有一个空行? 不完全是因为这个原因,但是如果您使用cx1[0]文件,并 ...

  5. 【已解决】PEP 8: W292 no newline at end of file等相关PEP 8错误与警告

    最近pycharm总是报这些错误与警告,真是逼死强迫症啊,因此搜索才知道这是PEP8规范( Python Enhancement Proposal ),线总结如下: 注:例图中的错误位置在波浪线出! ...

  6. Git 操作遇到 Found a swap file by the name “~/xxxx/.git/. COMMIT_EDI_TMSG. Swp“

    出错背景: 出现的原因是合并过一次节点,并且再次有修改后,使用 --amend 提交,就出现了 Found a swap file by the name "~/Desktop/gm_sta ...

  7. Git:bash: cd: No such file or directory

    Git:cd到制定文件夹 出现No such file or directory问题 解决办法,通过尝试,发现并不能一步就cd到制定文件夹,需要一步一步转换,需要一步一步的到你指定路径,如下图所示,暂 ...

  8. R,Git和Github(上)

    作者:Wenhu 博客:http://bioinfostar.com/ 本讲为第一部分,介绍git的"足够你用"命令:第二部分,还将介绍github的主要用途以及如何在R中使用gi ...

  9. Android开发学习之路-Git的极简教程?

    Git是一个代码版本管理工具,也就是允许我们的一个项目拥有多个版本,这样我们可以随心所欲的修改我们的代码,如果出现问题,可以回退到某一个提交点.如果你还在用一堆堆注释来更新你的代码,那么可以尝试一下G ...

最新文章

  1. 谷歌2019博士生奖研金名单:清华、上交大、港中文入选最多
  2. 斯坦福大学公开课:iPhone开发教程2010年冬
  3. KUDU--秒级查询的数据仓库
  4. acrobat 下拉列表 逻辑_记一次 无限列表 滚动优化
  5. bzoj3144: [Hnoi2013]切糕(最小割)
  6. 计算机网络【3】网络层
  7. 让你更中立!腾讯微信进行灰度测试 “好看”变为“在看”
  8. 连锁零售行业ERP解决方案
  9. 二叉树 -- 5.1.1 Binary Tree Level Order Traversal-1 -- 图解
  10. 项目中的常量是放在接口里还是放在类里呢?
  11. Atitit 研发团队建设----福利法案--非物质福利与物质福利法案
  12. MATLAB 均值估计函数normfit
  13. 华为服务器维护宝典,华为交换机在江湖之维护宝典,用户登录教你玩转密码
  14. 如何分辨usb压枪芯片是无后座压枪还是键鼠模拟压枪
  15. 同义词(近义词)算法总结(附代码)
  16. 一分钟学会清理垃圾运行命令
  17. 热更新Sophix的爬坑之路
  18. [数据结构]--WiscKey: Separating Keys from Values in SSD-Conscious Storage
  19. ABAP 日期格式转换(将XXXX-XX-XX或XXXX/XX/XX或XXXX.XX.XX转换XXXXXXXX格式)
  20. 無間道III 終極無間

热门文章

  1. Labplus:Scratch创作工具的替代与进步
  2. 文本比较算法剖析(1)-如何确定最大匹配率
  3. 对坐标的曲线积分求做功_对坐标的曲线积分对弧长的曲线积分 二重积分
  4. 累次积分怎么计算_什么是累次积分
  5. 线性代数-MIT 18.06-5(b)
  6. 如何在win10 安装ADS1.2
  7. Windows系统的重要文件目录
  8. 【论文笔记_自蒸馏_2021】GROUND-TRUTH TARGETS DAMPEN REGULARIZATION IMPOSED BY SELF-DISTILLATION
  9. 活动倒计时的一些想法
  10. 微信公众号注册已达上限怎么办?提升限额方法来了