当前位置:  开发笔记 > 编程语言 > 正文

istream_iterator迭代二进制文件中的字节

如何解决《istream_iterator迭代二进制文件中的字节》经验,为你挑选了2个好方法。

给定包含以下十六进制代码的文件:0B 00 00 00 00 00 20 41

我正在尝试填充std :: vector ,然后手动检查每个字节.

这是我使用迭代器构造函数从两个std :: istream_iterators创建向量的代码

using Bytes   = std::vector;
using ByteItr = std::istream_iterator;

Bytes getBytes()
{
    std::ifstream in;
    in.open("filepath");
    in.seekg(0, std::ios::beg);
    Bytes bytes;
    ByteItr start(in);
    ByteItr end;
    return Bytes(start, end);
}

这是我试图通过的单元测试:

auto bytes = getBytes();

REQUIRE( bytes.size() == 8 );

CHECK( bytes[0] == 0x0B );
CHECK( bytes[1] == 0x00 );
CHECK( bytes[2] == 0x00 );
CHECK( bytes[3] == 0x00 );
CHECK( bytes[4] == 0x00 );
CHECK( bytes[5] == 0x00 );
CHECK( bytes[6] == 0x20 );
CHECK( bytes[7] == 0x41 );

为什么在这种情况下,它会跳过两个元素并隐式将我的std :: uint8_t向量转换为无符号字符?



1> Benjamin Lin..:

istream_iterator不应该用于读取二进制文件.它使用operator>>,也不适合读取二进制文件(除非这些文件是大多数二进制文件不适合的特定格式).你可以istreambuf_iterator改用.您还希望确保以二进制模式打开文件.

in.open("filepath", std::ios::in | std::ios::binary);



2> Dietmar Kühl..:

不要使用std::istream_iterator:那是用于文本格式的输入.例如,它很可能会跳过空格(你可以禁用跳过空格std::noskipws,但这仍然是错误的事情 - std::istreambuf_iterator改为使用;类型char是流的字符类型).

此外,在处理二进制数据时,请确保以二进制模式打开流以避免行结束转换(如果您在执行行结束转换的平台上尝试此操作).也就是说,您将添加std::ios_base::binary到打开模式.

推荐阅读
ar_wen2402851455
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有