当前位置: 首页 > 面试题库 >

“写入”功能的正确缓冲区大小是多少?

拓拔辰钊
2023-03-14
问题内容

我正在使用低级I /
O函数“写入”以我的代码(Linux上的C语言)将一些数据写入磁盘。首先,我将数据存储在内存缓冲区中,然后在缓冲区已满时使用“写入”将数据写入磁盘。那么“写”的最佳缓冲区大小是多少?根据我的测试,更快不是越大,所以我在这里寻找答案。


问题答案:

进行写操作可能是文件系统块大小的倍数,因此可能会有一些优势,尤其是在就地更新文件的情况下。如果向文件中写入的块少于部分块,则操作系统必须读取旧块,合并新内容,然后将其写出。如果您快速按顺序快速写入小片段,则不一定会发生这种情况,因为更新将在内存中的缓冲区中完成,随后将刷新这些缓冲区。但是,如果您每次执行写操作都没有填充一个块(以及一个正确对齐的块:块大小的倍数,偏移量是块大小的倍数),有时您可能会触发一些低效率的操作。

传输大小的问题并不一定会随着mmap消失。如果先映射文件,然后再将memcpy一些数据映射到地图中,则将使页面变脏。该页面必须在以后的某个时间刷新:它的时间不确定。如果您制作另一个memcpy触摸同一页面的页面,则该页面现在可能已经干净了,并且您又使它变脏了。因此它被写入两次。与页面对齐的副本(页面大小的倍数)将是解决方法。



 类似资料:
  • 问题内容: 读取文件太大而无法容纳缓冲区时,出现致命错误。 要么, RangeError:“ size”参数不得大于Function.Buffer.allocUnsafe(buffer.js:209:3)的2147483647 如果我尝试分配1GB缓冲区,则会遇到同样的致命错误, Node.js Buffer类实例的最大大小是多少? 问题答案: V8中类型化数组的最大长度当前设置为以下值,具体取决

  • 问题内容: 构造函数中的缓冲区大小是什么意思? 当我编写程序时: 输出: 然后,缓冲区大小是什么意思,正如我希望的那样,它只能读取两个字符。但事实并非如此。 问题答案: 顾名思义,缓冲输入。这意味着它会在将输入源传递给您之前从输入源读取到缓冲区。此处的缓冲区大小是指其缓冲的字节数。 从大多数来源读取输入非常慢。仅2个字节的缓冲区将损害性能,因为您的程序很可能大部分时间都在等待输入。缓冲区大小为2时

  • 问题内容: 我正在尝试创建一个异步通道,并且一直在查看http://golang.org/ref/spec#Making_slices_maps_and_channels。 缓冲区大小为10是什么意思?缓冲区大小具体代表/限制了什么? 问题答案: 缓冲区大小是在没有发送阻塞的情况下可以发送到通道的元素数。默认情况下,通道的缓冲区大小为0(可通过来获得此值)。这意味着每个发送都会阻塞,直到另一个go

  • 问题内容: 假设我想在syscall 上的Linux文件系统上写入1 GB的数据,这种情况发生在非常 繁忙的环境中 (许多相似的I / O并发)。什么是在区间的最佳缓冲区大小,说,这样做,当 不使用打开标志,或者 使用? 请没有“自己检查”的答案-我想从“文件系统”的家伙那里得到一些答案。 问题答案: 正如评论中所讨论的那样,我认为确切的大小并不重要,假设是: 文件系统大小的一小部分(请参阅Joa

  • ByteArrayOutputStream(int size)-创建一个新的字节数组输出流,具有指定大小的缓冲区容量(以字节为单位)。 ByteArrayOutputStream()在默认情况下有32个字节的缓冲区,这就是Apache Commons有完全相同的类org.Apache.Commons.io.output.ByteArrayOutputStream的原因:“最初的实现一开始只分配32

  • 问题内容: 今天,我了解到,将stdout设置为terminal并在不同情况下进行缓冲时,它是行缓冲的。因此,在正常情况下,如果我使用printf()而不以“ \ n”结尾,则仅在缓冲区已满时才在屏幕上打印它。如何获得此缓冲区的大小,这有多大? 问题答案: 实际大小由各个实现定义;该标准并没有规定最小大小(无论如何,基于我已经能够找到的大小)。没有关于如何确定缓冲区大小的线索。 编辑 章节: 7.