我在读取二进制文件并将其字节转换为十六进制表示时遇到了一些问题。C++读取二进制文件并将其转换为十六进制
我试过到目前为止:
ifstream::pos_type size;
char * memblock;
ifstream file (toread, ios::in|ios::binary|ios::ate);
if (file.is_open())
{
size = file.tellg();
memblock = new char [size];
file.seekg (0, ios::beg);
file.read (memblock, size);
file.close();
cout << "the complete file content is in memory" << endl;
std::string tohexed = ToHex(memblock, true);
std::cout << tohexed << std::endl;
}
转换为十六进制:
string ToHex(const string& s, bool upper_case)
{
ostringstream ret;
for (string::size_type i = 0; i < s.length(); ++i)
ret << std::hex << std::setfill('0') << std::setw(2) << (upper_case ? std::uppercase : std::nouppercase) << (int)s[i];
return ret.str();
}
结果:53514C69746520666F726D61742033
。
当我打开用十六进制编辑的原始文件,这是它表明:
53 51 4C 69 74 65 20 66 6F 72 6D 61 74 20 33 00
04 00 01 01 00 40 20 20 00 00 05 A3 00 00 00 47
00 00 00 2E 00 00 00 3B 00 00 00 04 00 00 00 01
00 00 00 00 00 00 00 00 00 00 00 01 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 05 A3
00 2D E2 1E 0D 03 FC 00 06 01 80 00 03 6C 03 D3
有没有办法用C来获得相同的期望输出++?
工作液(罗布):
...
std::string tohexed = ToHex(std::string(memblock, size), true);
...
string ToHex(const string& s, bool upper_case)
{
ostringstream ret;
for (string::size_type i = 0; i < s.length(); ++i)
{
int z = s[i]&0xff;
ret << std::hex << std::setfill('0') << std::setw(2) << (upper_case ? std::uppercase : std::nouppercase) << z;
}
return ret.str();
}
“memblock只包含前15个字节,停在空字节(第16个)”是什么让你说的?我看不出你在哪里打印出'memblock'的内容。我怀疑'memblock'包含整个文件,但是你没有向我们展示的代码误解了它的内容。请将您的程序减少到显示错误的最小完整程序,并在问题中发布该程序。 http://sscce.org – 2012-03-08 17:20:07
@Rob好的,我应该转发前15个字节,让你更清楚吗? – technology 2012-03-08 17:21:46
假设这是一项家庭作业或某种学习任务,这里有几点提示:(1)缺少一个“while”循环,(2)在刚打开的流上调用tellg()为时尚早。 – dasblinkenlight 2012-03-08 17:22:22