我想证明像
这样的输出文本 0x29823d80 0x10019b8 / 0 00000000000000000000000000000001
0x37449e60 0x10dfc / 12 00000000000000000001000000000000
然而,这句话
fout << std::setw(5) << std::hex << "0x" << (*it).addr << " "
<< std::setw(5) << std::hex << "0x" << (*it).pc << std::setw(10) << "/" << std::setw(5) << std::dec << (*it).off << "\t"
<< std::setw(5) << (*it).layout << "\n";
我明白了:
0x29823d80 0x10019b8 / 0 00000000000000000000000000000001
0x37449e60 0x10dfc / 12 00000000000000000001000000000000
答案 0 :(得分:5)
此值不是“粘性”:受流宽度字段值影响的下一个输入或输出操作会将其重置为零(表示“未指定”)。
这意味着您所做的setw
用于字符串"0x"
而不是实际的十六进制数。你必须在之前使用setw
你想要证明的输出。
编辑:您的问题的一个解决方案是使用包含前导"0x"
的临时字符串,以及使用这些字符串的格式:
std::ostringstream val1, val2;
val1 << "0x" << std::hex << (*it).addr;
val2 << "0x" << std::hex << (*it).pc;
fout << val1.str() << " " << val2.str()
<< std::setw(10 + 10 - val2.str().length())
<< '/' ...
我从上面得到的表达式10 + 10 - val2.str().length()
:
10
,因为您似乎想要在数字和斜线之间留出10个空格10
,因为它允许8个十六进制数字(32位)加上前导"0x"
您可以使用此方法here查看示例。
答案 1 :(得分:1)
我知道这可能不是你所追求的,但请记住C
主要是C++
的一个子集,你尤其可以使用fprintf函数,它更适用于格式化简单的字符串和数字,而不是C++
I / O工具。有了这个,你只需写:
fprintf(file, "%10p %10p / %5d %d\n", it->addr, it->pc, it->off, it->layout);
答案 2 :(得分:1)
如有疑问,请使用更多setw
!此外,您可以使用setfill
使数字看起来更漂亮:
std::cout << "0x"
<< std::hex << std::setfill('0') << std::setw(10) << (*it).addr
<< std::setw(5) << std::setfill(' ') << "0x"
<< std::hex << std::setfill('0') << std::setw(10) << (*it).pc
<< std::setw(10) << std::setfill(' ') << "/"
<< std::dec << std::setw(5) << (*it).off
<< std::setw(33) << (*it).layout
<< std::endl;
产地:
0x0029823d80 0x00010019b8 / 0 00000000000000000000000000000001
0x0037449e60 0x0000010dfc / 12 00000000000000000001000000000000