由于JavaScript對浮點數的支持很弱,直接使用浮點數轉十六進制功能,雙不能實現平常在C語言中實現的4字節的存儲表示法,通過搜索,并沒有找到相關功能代碼,在Node.js的Buffer類可以實現此功能,但又沒辦法使用(單片機存儲空間有限),也沒辦法找到具體是如何實現的(看不太懂)。
例如:
123.456 ==》 0x42F6E979在C語言中,直接將一個浮點數轉換成unsigned int再輸出成十六進數就可以了,但在JavaScript中實現就不那么直接了。
有幸在網上找到了一個用C#實現的IEEE754標準的浮點數轉換代碼(IEEE754浮點數轉換器(C#實現)點擊打開鏈接),通過將此代碼轉換成JavaScript,完成了此份工作,為此,將代碼貼出來,共享。
另外,我只實現了轉成十六制,沒有實現逆轉(逆轉代碼)在C#代碼中也有。
通過如下代碼可以實現如下:
get_float_hex(123.456) ==> 42F6E979
代碼如下:
function DecToBinTail(dec, pad)
{
var bin = "";
var i;
for (i = 0; i < pad; i++)
{
dec *= 2;
if (dec>= 1)
{
dec -= 1;
bin += "1";
}
else
{
bin += "0";
}
}
return bin;
}
function DecToBinHead(dec,pad)
{
var bin="";
var i;
for (i = 0; i < pad; i++)
{
bin = (parseInt(dec % 2).toString()) + bin;
dec /= 2;
}
return bin;
}
function get_float_hex(decString)
{
var dec = decString;
var sign;
var signString;
var decValue = parseFloat(Math.abs(decString));
if (decString.toString().charAt(0) == '-')
{
sign = 1;
signString = "1";
}
else
{
sign = 0;
signString = "0";
}
if (decValue==0)
{
fraction = 0;
exponent = 0;
}
else
{
var exponent = 127;
if (decValue>=2)
{
while (decValue>=2)
{
exponent++;
decValue /= 2;
}
}
else if (decValue<1)
{
while (decValue < 1)
{
exponent--;
decValue *= 2;
if (exponent ==0)
break;
}
}
if (exponent!=0) decValue-=1; else decValue /= 2;
}
var fractionString = DecToBinTail(decValue, 23);
var exponentString = DecToBinHead(exponent, 8);
return Right('00000000'+parseInt(signString + exponentString + fractionString, 2).toString(16),8);
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com