最近一個嵌入式項目中需要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 = "";
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);