由于JavaScript對(duì)浮點(diǎn)數(shù)的支持很弱,直接使用浮點(diǎn)數(shù)轉(zhuǎn)十六進(jìn)制功能,雙不能實(shí)現(xiàn)平常在C語(yǔ)言中實(shí)現(xiàn)的4字節(jié)的存儲(chǔ)表示法,通過(guò)搜索,并沒(méi)有找到相關(guān)功能代碼,在Node.js的Buffer類可以實(shí)現(xiàn)此功能,但又沒(méi)辦法使用(單片機(jī)存儲(chǔ)空間有限),也沒(méi)辦法找到具體是如何實(shí)現(xiàn)的(看不太懂)。
例如:
123.456 ==》 0x42F6E979在C語(yǔ)言中,直接將一個(gè)浮點(diǎn)數(shù)轉(zhuǎn)換成unsigned int再輸出成十六進(jìn)數(shù)就可以了,但在JavaScript中實(shí)現(xiàn)就不那么直接了。
有幸在網(wǎng)上找到了一個(gè)用C#實(shí)現(xiàn)的IEEE754標(biāo)準(zhǔn)的浮點(diǎn)數(shù)轉(zhuǎn)換代碼(IEEE754浮點(diǎn)數(shù)轉(zhuǎn)換器(C#實(shí)現(xiàn))點(diǎn)擊打開(kāi)鏈接),通過(guò)將此代碼轉(zhuǎn)換成JavaScript,完成了此份工作,為此,將代碼貼出來(lái),共享。
另外,我只實(shí)現(xiàn)了轉(zhuǎn)成十六制,沒(méi)有實(shí)現(xiàn)逆轉(zhuǎn)(逆轉(zhuǎn)代碼)在C#代碼中也有。
通過(guò)如下代碼可以實(shí)現(xiàn)如下:
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);
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com