首頁 >web前端 >js教程 >javaScript實作浮點數轉十六進位字元_javascript技巧

javaScript實作浮點數轉十六進位字元_javascript技巧

WBOY
WBOY原創
2016-05-16 17:18:211783瀏覽

最近一個嵌入式專案中需要WEB功能,因此想到利用HTML JavaScript實現一些參數配置功能,參數由JavaScript產生十六進位數據,透過POST提交給單片機,然後再直接使用,以充分利用瀏覽器的運算能力。

由於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 = ""; for (i = 0; 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 {
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;
exponent ;
decValue /= 2; }
}
else if (decValue{
while (decValue {
exponent--;
decValue *= 2
if
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 fraction, 2). 🎜>
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn