stl — сбросить шестнадцатеричное число в переполнении стека

Я попробовал следующее:

std::cout << std::hex << 17.0625;

Но это сбрасывалось в десятичном виде. Я хотел бы видеть 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;
}
}
}

Есть ли способ сбросить числа с плавающей точкой в ​​гекс в STL / boost?

6

Решение

Другие уже предложили решение C ++ 11, но у вашего вопроса нет тега C ++ 11. Вот решение ISO C99, использующее %a а также %la спецификаторы формата из стандарта ISO C99.

Я хотел бы видеть 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);

}

Вот пример, показывающий, как читать и записывать числа с плавающей запятой в шестнадцатеричном формате.

#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);

}

Если переносимость имеет значение, или вы застряли со старым компилятором, это разумный подход, по моему мнению.

4

Другие решения

Пытаться cout << std::hexfloat << 1.0625;
Это требует C ++ 11.

6

std::hexfloat является манипулятором формата для печати значений с плавающей запятой в шестнадцатеричном представлении. Он существует с 2011 года стандарта.

3
По вопросам рекламы ammmcru@yandex.ru
Adblock
detector