- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在Desiginin File Formats我从这个网站获得的链接,我注意到 png 有 CRLF\x1A\LF
block ,用于“测试”回车和换行符转换。
我正在为某个项目构建自定义二进制结构,我想知道为什么这很有用,在什么情况下我应该考虑添加它?
最佳答案
由于历史原因,不同的操作系统使用不同的序列来标记文本文件中的行结尾:
\n
(换行)\r\n
(回车、换行)\r
(回车)(Mac OS X(具有 BSD Unix 内核)可能同时支持:A Line Break Is a Line Break)。这一切都是一团糟,例如:
^M
修饰。在行尾。一旦您定期在不同的操作系统之间切换,您就会开始习惯于必须不时修复行尾。有许多帮助工具,例如unix2dos
和 dos2unix
在cygwin中,Notepad++中的特殊命令,VisualStudio中的提示等。
在 C 语言中,行尾总是用 \n
标记即使在 DOS 和 Windows 中。 (我没有使用 Mac OS 的经验,但我想知道它是否与那里不一样。)为了使它无缝运行,MS 决定在“底层”读取和写入时“修复”文件内容。读取文件时,所有出现的 \r\n
被 \n
默默取代写入文件时插入一个 \r
每写之前\n
.
这有一些恼人的缺点:
如果读取特定大小的文件,“接收到”的内容可能会小一些字节。 (当我试图在加载文件之前预留空间并一次读取全部内容时,我曾经偶然发现了这个问题。我想知道为什么加载后某些字节似乎丢失了。)
这可能会中断二进制文件的加载,其中 \n
简单地表示具有任何含义的二进制值 10(超出换行符)。
为了解决这个问题,C API 为文件 I/O 提供了额外的模式。例如。 fopen()
支持超过r
, w
, 和 a
, 一个额外的字符来指示文件类型
b
表示二进制 I/O(不要触摸内容)t
表示文本 I/O(修复行尾)。没有它们,默认是文本 I/O。
在 Windows 以及可移植文件 I/O 上,应该始终给出。 (在 Linux 上,它根本没有任何影响,尤其是没有破坏性。)
我曾经写过SO: Copying a bmp in c的答案其中损坏的 BMP 文件的转储很好地说明了错误完成文件输出的影响。
在这个关于文本和二进制文件 I/O 的长篇故事之后,很明显,对于处理图像数据(通常是二进制编码)的开发人员来说,这始终是一个潜在问题。
因此,我可以想象 \r\n\032\n
sequence 只是一个测试模式。如果这 4 个字节不完全具有这些值,则很有可能
It will allow the decoder to throw useful error messages in that case as opposed to failing mysteriously.
关于c++ - png 中 CRLF CR block 的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56951452/
我有一个包含“CRLF”和“LF”作为行分隔符的字符串。 我只想用“LF”(空格和LF)替换“CRLF”并保持“LF”不变。 我知道,我们可以使用正则表达式来做到这一点,但我已经从现有的答案中尝试了一
我需要将所有新行分隔符更改为\r\n。在字节表中有一些\r 和一些\r\n byte[] data = (byte[])transformedToByteObject; 数据包含该字节,但我不知道如何
在 Veracode 报告中,我在一些 java 文件中收到错误 CWE 93。在静态扫描实例中,一些代码是 MimeMessage msg = new MimeMessage(session); m
这段代码: InternetAddress[] myAdrs = getAdrs(message.getToAddresses()); for (int i = 0; i Impro
我一直在尝试使用 openssl 与 smtp.gmail.com 端口 587 或 465 建立连接:openssl s_client -主机 smtp.gmail.com -端口 587 -sta
我有一个 PHP 文件,需要对其进行简单的文本更改。我使用FTP从linux服务器复制到我的Win7机器。我用 Notepad++ 打开它,打开-查看-显示符号-查看所有字符-我可以在每行前后看到CR
我们有一个数据源,它向我们发送我们需要自动导入到我们系统中的文件,但在某些记录的一个或两个字段中,这些文件中经常存在以额外 CRLF 形式出现的错误数据。该文件是一个 CSV 格式文件,最初我以为我已
我编写了一个小程序,它将多段字符串作为参数上传。当我在 Netbeans 中测试它时,它保留了 CRLF,但是当我在应用程序中实时部署它时,它会丢弃它们为什么会发生这种情况以及我该怎么办? 最佳答案
我有一个文件,我想读取每一行的字符串。如果该行不以 CRLF (\r\n) 结尾,我想打印一些内容。我通过重定向打印命令的输出来创建此文件,如下所示。 System.out.println("Test
我不知道在发送正文的所有字节后我是否应该发送下一条消息而不用 CRLF 将第一条消息的正文分隔到第二条消息的起始行。 这是根据 RFC 7230 的语法: HTTP-message = star
使用 StringBuilder 并在我的字符串中使用 Environment.NewLine,当我打开它时它显示为 CRLF,C# 中是否有其他命令输出仅显示为“LF”而不是“CRLF”? 最佳答案
我得到了一个带有 HTTP 请求内容的字符串流。如您所知,HTTP 请求以 CRLF 中断结束。但是 operator>> 不会将 CRLF 识别为正常的文件结尾。我怎样才能检测到这个 CRLF 中断
我想在我的项目中确保 CRLF(Windows 风格)行分隔符。我正在检查一些替代方案,但不确定哪一个是最好的。 期望的行为: 如果文件不是 CRLF,则 IntelliJ IDEA 显示在底部: 我
目标是使用批处理脚本执行以下操作: 从 Windows 机器中提取主机名。 在主机名值(从第 1 步获得)上应用 sha256 哈希。 我的系统主机名是:W0000000000ZQ 我的批处理脚本如下
我是 VBScript 新手。我正在尝试编写一个函数来识别打印行中是否有 CRLF。你能帮我吗? 谢谢 最佳答案 您可以简单地使用result = Instr(yourString, vbCRLF)。
这个简单的解析器预计会解析以下形式的消息 key: value\r\nkey: value\r\n\r\nkey: value\r\nkey: value\r\n\r\n 一个 EOL 作为字段分隔符
我有一个 lua 文件。它读取 2 个文件,一个“脚本”文件,一个“源”文件。 lua文件解释脚本文件并用脚本文件中的一些指令更改源文件(在内存中)。然后将此修改后的源输出到输出文件中。在 CR 之前
我试图强制我的 spring 批处理始终使用 CR-LF[EDIT] 作为行分隔符来写入文件,而不管底层系统如何。 我试图使用 FlatFileItemWriter 的 setLineSeperato
如何从一组数据中解析出不需要的字符? 我正在使用 Windows 应用程序的现有 VB.NET 代码,该应用程序使用 StreamWriter 和 Serializer 来输出交易数据的 XML 文档
实现这一点的简单方法是: import re re.split(r'(?:\r\n|\r|\n){2}', '...') 但是: >>> re.split(r'(?:\r\n|\r|\n){2}',
我是一名优秀的程序员,十分优秀!