为什么以文本形式打开图像文件会打印奇怪的字符?



每次我打开jpeg,png,ico等时,它总是打印这个。为什么我打开它,因为我认为每个软件都有一个代码,但那些处理图像或颜色的软件恰好很奇怪?那么谁能解释一下呢?

MZ       ÿÿ  ¸       @                                   €   º ´    Í!  ¸      LÍ!This program cannot be run in DOS mode.
$       PE  L OhAY        à   8         þU       `    @                                  @…                           °U  K    `  ø                   €                                                                       H           .text   6       8                    `.rsrc   ø   `        :              @  @.reloc      €      >              @  B                àU       H     ¸+  ø)                                                       0      %{  
(  
*  0! 4    r  p{  
(  
Ð  r  pr  p  %r-  p¢%r1  p¢%r;  p¢%rE  p¢%rQ  p¢  %r-  pÐ  s  
¢%r1  pÐ  s  
¢%r;  pÐ  s  
¢%rE  pÐ  s  
¢%rQ  pÐ  s  
¢%r]  pÐ  s  
¢%re  pÐ  s  
¢r  p{  
(

只有纯文本文件存储在纯文本中。图像、程序、视频、音乐和大多数其他文件以各种二进制格式存储。在文本编辑器中打开二进制文件时,它假定您告诉它打开的文件是纯文本并开始读取数据。文本编辑器按顺序读取每个数据块(可以认为是一系列数字),并将数据转换为相应的文本字符。由于文件中的数据是二进制的,因此数据不打算显示为字符,我们看到大量随机字符。这是一个相当大的简化,但它足够接近,应该可以帮助您理解。

如您所见,必须有一些纯文本存储在该格式中,因为我们可以读取This program cannot be run in DOS mode.和其他一些随机文本位。

此外,计算机上的文件不是程序,除非它们以.exe结尾(这也是一种简化,但足够接近)。例如,双击图像文件会告诉操作系统启动图像编辑程序,操作系统会告诉程序打开图像。图像本身不是一个程序。

但是,我建议您阅读以下内容:我如何提出一个好问题?这个问题可能更适合 https://superuser.com/。


值得一提的是,从技术上讲,每个文件都存储在二进制甚至纯文本文件中。纯文本编辑器希望文件的每个字节对应于单个字符(通常来自 ASCII 表)。当您在纯文本编辑器中打开图像文件时,它将尝试将图像文件的每个字节解释为文本,但图像文件中的字节不应作为字符读取,因此它们将作为无意义的字符出现。

这就像看时钟,用字母表中的字母替换当前时间的每个数字(比如9:23)。字母表的第 9 个字母是 I,第 2 个是 B,第 3 个是 C,这给了我们 IBC。"但这不是一个词!"你可能会说。当然不是。我们只是试图将时间读成字母,所以它被当作胡说八道。这基本上就是在文本编辑器中打开图像文件时发生的情况。

最新更新