在C++中转储hex float

Ser*_*gei 6 c++ double hex stl dump

我试过以下:

std::cout << std::hex << 17.0625;
Run Code Online (Sandbox Code Playgroud)

但它把它倾倒在十进制中.我想看11.01(17.0625十六进制).如何以十六进制打印一些浮点值?

请不要提供以下解决方案:

void outhexdigits(std::ostream& out, fp_t d, int max_chars=160)
{
    while(d > 0. && max_chars)
    {
        while(d < 1. && max_chars){
            out << '0';
            --max_chars;
            d*=16;
        }

        if (d>=1. && max_chars) {
            int i = 0;
            while (d>=1.)
                ++i, --d;
            out << std::hex << i;
            --max_chars;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

有没有办法在STL/boost中以十六进制转储浮点数?

Cha*_*ian 6

试试cout << std::hexfloat << 1.0625; 这需要C++ 11.


Ali*_*Ali 5

其他人已经提出了 C++11 解决方案,但您的问题没有 C++11 标签。这是一个 ISO C99 解决方案,使用ISO C99 标准中的%a%la格式说明符。

我想看到 11.01(十六进制为 17.0625)。

以下程序打印0X1.11P+4.

#include <stdio.h>

int main() {

  double x = 17.0625;

  printf("17.0625 in hexadecimal is: %A\n", x);  

}
Run Code Online (Sandbox Code Playgroud)

这是一个示例,显示如何以十六进制格式读取和写入浮点数。

#include <stdio.h>

int main() {

  double x = 0.1;

  char* str = "0X1.999999999999AP-4";

  printf("0.1 in hexadecimal is: %A\n", x);

  printf("Now reading %s\n", str);

  /* in a production code I would check for errors */
  sscanf(str, "%lA", &x); /* note: %lA is used! */

  printf("It equals %g\n", x);

}
Run Code Online (Sandbox Code Playgroud)

如果可移植性很重要,或者您坚持使用较旧的编译器,那么我认为这是一种合理的方法。