用SETW证明文本是合理的

justify text with setw

本文关键字:文本 SETW 证明      更新时间:2023-10-16

我想像这样证明输出文本

 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 

来自此参考:

此值不是"粘性":由流的宽度字段值影响的下一个输入或输出操作,将其重置为零(含义为"未指定")。

这意味着您要做的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"
  • 调整数字字符串的实际长度

您可以在此处使用此方法看到一个示例。

我知道这可能不是您所追求的,但请记住,C主要是C++的子集,尤其是您具有可用函数FPRINTF,这更适合比C++ I/O设施格式化简单的字符串和数字。因此,您只需写下:

fprintf(file, "%10p %10p / %5d %dn", it->addr, it->pc, it->off, it->layout);

如有疑问,请使用更多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