c++ - 多线程写入文件C++

标签 c++ multithreading openmp

我有一个包含整数数据的大缓冲区(一个大整数数组),我想将其写入文件。

但是我正在使用 openMP,我的整个应用程序现在是多线程的。所以我想知道,在缓冲区已满之后,有没有办法让我使用 openMP 并让多个线程写入同一个文件,从而对缓冲区进行多次只读访问?

如果使用 openMP 是不可能的,是否可以通过其他方式进行?我应该怎么做?

有没有你知道的图书馆可以做这件事?

最佳答案

多个线程写入一个文件会使进程比现在更慢,因为这将强制执行许多seek 操作(考虑到默认的磁性 HDD,这是最慢的操作)。

考虑只用一个线程将数据写入磁盘,但读取是用多个线程直接访问内存数组进行的。一旦不再分配该数组,就应该在磁盘上执行访问,由于寻道时间再次导致速度变慢。要降低速度,您必须实现某种缓冲方案或仅使用一个线程。

根据您的读数执行方式和算法实现方式,还有其他需要考虑的事项,但我相信这些是一些通用线路。

关于c++ - 多线程写入文件C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15463606/

相关文章:

c++ - 具有两个串联线程的 OpenMP 填充数组

c++ - 如何在 Solaris 系统中以 C/C++ 编程方式获取进程信息?

java - 有效的 Java 项目 66 : Why to synchronize both read and write methods?

multithreading - 由于异步,在 WebApi 中使用 HttpContext.Current 是危险的

c++ - 任务内的 OpenMP 任务循环

c++ - OpenMP 线程、数据访问延迟和 STL 数据容器

c++ - 快速可变大小容器 C++

c++ - C++中的欺骗文件描述符

c++ - 将 kde 应用程序移植到 windows

c - 对 mprotect 的调用太多