文件与数组,哪一个更快?

时间:2016-01-01 17:11:06

标签: c arrays performance file

我制作了一个程序,在一个循环中多次读取文件中的字符。 如果我不关心内存使用情况,那么将文件的所有字符存储在一个数组中比使用fgetc访问字符更快?

2 个答案:

答案 0 :(得分:4)

一般而言,如果不了解平台的详细信息以及您想要比较的确切代码,就无法回答性能问题。但是,在这种情况下,在大多数平台上缓冲数组中的文件内容可能要快得多。

首先,磁盘比主存慢一个数量级。

即使您的操作系统(或libc)将数据缓存在RAM中,fgetc仍会执行系统调用来获取它,这可能比简单的内存读取慢得多。

同样由于系统调用相对较慢,使用fread代替fgetc来读取单个调用中的字节块。

答案 1 :(得分:1)

我认为你至少应该使用某种形式的缓冲,而不是一次读取一个字符来填充缓冲区或数组。

最好使用fread()填充缓冲区/数组,或者甚至可以查看内存映射(mmap),以避免在内核模式下将数据从磁盘缓存复制到用户模式下的缓冲区如果你想要稍微提高性能(因为你的问题也被标记为performance)。虽然,对于单次读取传递,您的硬盘肯定会是僵尸。

如果您只需要读取一次数据,可以使用带有缓冲区的fread()