【踩坑日记】因不同系统换行符不同导致的文本读取结果不同的问题

1 问题现象描述

起因是群友问了这么一个问题
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
确实很奇怪,按理说第二个printf不会完全不输出,于是想到,会不会是printf缓冲器的锅,让群友尝试刷新缓冲区,无果

2 解决过程(点击直接跳到解决方法)

于是我将代码克隆到本地的win环境运行,却发现输出正常:
在这里插入图片描述
这就很奇怪了,我的环境运行正常,而群友运行就不正常,开始怀疑是不是其环境的问题

此时,注意到其用的是 WSL 的 Ubuntu 环境,于是我尝试在我的 WSL 的 Ubuntu 环境下运行,结果问题真的复现了!

3 原因解释

丢给gpt进行解释,原来我们忽略了一个重要的问题:不同系统的回车换行符是不同的

系统换行符
Windows\r\n
UNIX、Linux\n
macOS\r

Linux会将连一起的\r\n解释会回车换行,\n也会解释为回车换行,但是如果\r不和\n一起出现,\r将被解释为回车符,也就是光标回到当前这个 printf 输出的内容的开始,如果后面继续输出,将会覆盖当前这个 printf 输出的内容。

  • 如图,\r\n被linux解释为回车换行:
    在这里插入图片描述
  • 单独的\n也被 linux 解释为回车换行
    在这里插入图片描述
  • 而单独的\r被 linux 解释为回车,输出 bb 后,由于光标回到了第一个 b,下次输出的 c 直接覆盖了第一个 b
    在这里插入图片描述

4 如何避免踩坑

在处理文本文件时,应确保文件格式符合当前系统的要求。

4.1 格式转换

  • 如果在 Linux 中,可以使用命令行命令对文件进行格式转换:
# 将UNIX / Linux格式的文件转换为DOS格式
unix2dos 文件名

# 将DOS格式的文件转换为UNIX / Linux格式
dos2unix 文件名

4.2 格式查看

cat -A 文件名
  • aaaa^M$ 表示文件中存在以下内容:
    • aaaa 是4个 ‘a’ 字符
    • ^M 表示一个 Windows 风格的回车符 (Carriage Return)
    • $ 表示一个 Unix 风格的换行符 (Newline)

这说明该文件使用了 Windows 风格的换行符,而不是 Unix/Linux 的换行符 (\n)。为了在 Unix/Linux 系统上正确显示该文件,需要使用 dos2unix 命令将其转换为 Unix 格式。
在这里插入图片描述

  • 12
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

__Witheart__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值