用setw证明文本

时间:2012-10-31 13:51:13

标签: c++ setw

我想证明像

这样的输出文本
 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 

3 个答案:

答案 0 :(得分:5)

来自this reference

  

此值不是“粘性”:受流宽度字段值影响的下一个输入或输出操作会将其重置为零(表示“未指定”)。

这意味着您所做的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