是否可以/值得使用内存映射文件来写入/读取协议缓冲区
Is using memory mapped files possible/worthwhile for writing/reading protocol buffers?
我正在使用FileOutputStream
实例(由CodedOutputStream
对象包装)来编写协议缓冲区输出。
我想知道是否可以使用内存映射文件,这样做是否会带来显著的性能改进。
谢谢。
实现这一点是可能的,但您不太可能看到任何性能提升。在您描述的场景中,使用流对象和文件映射之间的唯一区别是哪个子系统正在执行I/O(启动读/写)。对于文件映射,内存管理器处理读取操作的生成页面错误,并在空闲时保留脏(写)页面。
对于序列化协议缓冲区,老式的基于流的文件I/O是最简单、最便携的解决方案。
相关文章:
- 理解boost::asio-async_read在无需读取内容时的行为
- 使用新行和不使用新行读取文件
- 读取文件并输入到矢量中
- 用c++从输入文件中读取另一行
- 读取文件的最后一行并输入到链接列表时出错
- 在进程中对同一管道进行读取和写入时C++管道出现问题
- 无法找到/读取配置文件.conf-FileIOException
- 如何使用Luacneneneba API正确读取字符串和表参数
- C++将文本文件中的数据读取到结构数组中
- 正在将csv文件读取为双精度矢量
- 为什么 sscanf 无法从一个字符串中读取uint64_t和字符?
- 为什么在读取文件大小时文件IO速度会发生变化
- 正在读取二进制文件(is_open)
- 如何在c++中从文本文件中逐行读取整数
- SSH通过/sbin/SSH无法读取RSA密钥文件(从控制台运行)
- 独立读取-修改-写入顺序
- 协议缓冲区-读取所有消息中通用的标头(嵌套消息)
- 读取协议缓冲区中枚举扩展的值
- 是否可以/值得使用内存映射文件来写入/读取协议缓冲区
- 使用协议缓冲区从文件读取消息时出现问题