[英]copying from a std::istreambuf_iterator<> to a std::vector<>
[英]Getting desired binary data ranges from std::istreambuf_iterator and std::ifstream
#include <iostream>
#include <fstream>
#include <iterator>
#include <vector>
int main()
{
std::ifstream file("data.bin", std::ios::binary );
if( file.fail() )
{
std::cout << "File does not exist or could not open file";
return 0;
}
std::vector<short> buffer;
std::copy(
std::istreambuf_iterator<char>( file ),
std::istreambuf_iterator<char>(),
std::back_inserter( buffer )
);
return 0;
}
这只给出了char值范围(-128,128)。
我以为使用istreambuf_iterator<short>
会给我我想要的但是它会引发“无效转换”错误。
我该怎么做才能读取short
二进制值?
类std::istreambuf_iterator<cT>
遍历从std::basic_istream<cT, std::char_traits<cT>>
提取的字符std::basic_istream<cT, std::char_traits<cT>>
或者实际上,它的std::basic_streambuf<cT, std::char_traits<cT>>
。 也就是说,给定特定的流类型, std::istreambuf_iterator<cT>
没有选择。 另请注意,尽管传递给流缓冲区的std::ios_base::binary
操作,IOStream层并不打算对二进制文件进行操作。
如果要提取short
(或者流的字符类型之外的任何其他类型),您需要自己创建一个合适的迭代器,该迭代器将所选的二进制格式考虑在内。 这个迭代器可以用std::istreambuf_iterator<char>
构建,也可以直接访问std::streambuf
。
这是我推荐的Spirit方法:
#include <fstream>
#include <boost/spirit/include/qi.hpp>
namespace qi = boost::spirit::qi;
int main()
{
std::ifstream file("data.bin", std::ios::binary);
if(!file)
std::cout << "File does not exist or could not open file";
boost::spirit::istream_iterator f(file), l;
std::vector<int16_t> buffer;
bool ok = qi::parse(f, l, *qi::word, buffer);
}
当然,还有qi::dword
, qi::qword
,big-endian / little-endian variatations等:
你可以看看wchar_t
#include <iostream>
#include <fstream>
#include <iterator>
#include <vector>
int main()
{
std::wifstream file("data.bin", std::ios::binary );
if( file.fail() )
{
std::cout << "File does not exist or could not open file";
return 0;
}
std::vector<wchar_t> buffer;
std::copy(
std::istreambuf_iterator<wchar_t>( file ),
std::istreambuf_iterator<wchar_t>(),
std::back_inserter( buffer )
);
}
我不太确定wchar_t的实际大小是否是实现定义的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.