文件操作与罗马数字转换工具优化
1. 文本文件与数据文件
在文件操作中,我们会遇到不同类型的文件,主要有文本文件和数据文件。文本文件仅包含 ASCII 或 Unicode 字符,你可以使用任何文本编辑器(如 TextEdit 或 Xcode)打开并编辑它。而像“My Dinos”这样的文件,其扩展名是 .data 而非 .txt ,它不是文本文件,而是一种自定义的文件格式。这种文件中的字节可能并非有效字符,程序员将这些字节称为“垃圾字节”或“填充字节”。
若想查看这类非文本文件的数据,可以使用 hexdump 命令行工具。该工具能将文件的原始字节格式化为十六进制数字并输出到标准输出。其中, -C 选项是比较常用的,它会同时输出每个字节的十六进制值以及对应的 ASCII 字符(如果可能)。例如,在终端窗口中对“My Dinos.data”文件使用 hexdump -C 命令,就能看到文件的十六进制表示,文件偏移量也以十六进制显示。比如偏移量 00000020 实际上是十进制的 32(2×16 + 0),这解释了为什么第二个恐龙名字“Barney”看起来从偏移量 00000014 开始,因为在文件中这实际是偏移量 20(1×16 + 4)。
2. 字节序问题
在文件操作中,当使用 fread() 和 fwrite() 读写复杂变量(如 int 和 st
超级会员免费看
订阅专栏 解锁全文
25

被折叠的 条评论
为什么被折叠?



