如何在C++程序的中间写入昂贵的文件I/O
How to write-off an expensive file I/O in the middle of a C++ program
我正在编写一些性能要求极高的代码(我使用的是微秒计时器!)。问题是,它有一个服务器<->高速共享大量数据的客户端体系结构。为了保持客户端和服务器之间的同步,遵循了一种简单的基于"序列号"的方法。这样,如果客户端的程序崩溃,客户端可以通过向服务器发送最后一个序列号来"恢复"通信,他们可以"恢复操作"而不会错过任何东西。这个问题是我被迫将序列号写入磁盘。遗憾的是,每一笔"交易"都必须这样做。这种文件写入会造成巨大的时间成本(正如我们所预料的那样)。所以我想我应该使用线程来解决这个问题。然而,如果我创建了一个常规线程,我无论如何都必须等到文件写入完成。如果我使用了一个分离的线程,我会做一些有风险的事情,因为当我的实际进程被终止时(比方说),线程可能无法完成,因此序列号会被打乱。
我有什么选择。请注意,遗憾的是,我无法访问C++11。我在linux上使用lpthread。
您只需将数据添加到队列中,然后让辅助线程出列、写入并在完成后发出信号。
您还可以从基于日志的文件系统中获得一些灵感。他们通过让主线程首先将一个小记录写入日志文件,然后立即将控制权返回给程序的其余部分来解决这个问题。同时,辅助线程可以执行实际的数据写入,并通过写入日志文件发出信号。这有助于通过将写入延迟到有更多系统资源可用时来保持吞吐量,并且不会阻塞主线程。点击此处了解更多信息
相关文章:
- .cpp和.h文件中的模板专用化声明
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 文本文件中的单词链表
- CMake-按正确顺序将项目与C运行时对象文件链接
- 使用新行和不使用新行读取文件
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 挂起和取消挂起一个文件DLL
- 如何确定我已使用非编码文件到达 EOF?
- 命名空间中具有.h和.cpp文件的类
- 如何使用ndk-build.cmd构建Android.so文件
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 读取文件并输入到矢量中
- 在C++中查找文件
- c++库的公共头文件中应该包含什么
- 用c++从输入文件中读取另一行
- Cppcheck生成xml转储文件
- 读取文件的最后一行并输入到链接列表时出错
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 如何将内容数组写入文本文件?
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到