Имеется 4 байта представляющих число с плавающей запятой типа float (32 бита).
Как правильно организовать присвоение переменной типа float значения описанного в этих байтах.
Подскажите пожалуйста алгоритм.
Код
float F;
char Ch1, Ch2, Ch3, Ch4;
F = ??? (Ch1 + Ch2 + Ch3 + Ch4);
char Ch1, Ch2, Ch3, Ch4;
F = ??? (Ch1 + Ch2 + Ch3 + Ch4);
Пробую так, но может есть что-либо правильнее:
Код
float s;
signed short e;
long long m;
e = (((Ch1 & 0x7F) << 1) | (Ch2 & 0x80 >> 7)) - 127; //экспонента
m = (0x800000 | (((Ch1 & 0x7F) << 16) | (Ch2 << 8) | Ch3)); //мантисса
m >>= 23 - e;
s = pow(-1, Mass[0] >> 7); //знак
return(s * m);
signed short e;
long long m;
e = (((Ch1 & 0x7F) << 1) | (Ch2 & 0x80 >> 7)) - 127; //экспонента
m = (0x800000 | (((Ch1 & 0x7F) << 16) | (Ch2 << 8) | Ch3)); //мантисса
m >>= 23 - e;
s = pow(-1, Mass[0] >> 7); //знак
return(s * m);