我有一个用Little Endian格式编码的字符串(首先是最低有效字节),我想把它解码成一个数字。对于编码器,最后一个字节的第一位反映该数字是正数还是负数。有谁知道怎么做?
这是我的解码器:
decode:function(str,type){
var num=0;
var len=size(type)-(type.signed?1:0);
var totalBits=0;
for(var i=0;i<len;i++){
num+=(str.charCodeAt(i)<<totalBits));
totalBits+=8;
}
if(type.signed){
var b=str.charCodeAt(size(type)-1);
var neg=(b>=128);
if(neg){
b-=128;
}
num+=b;
num*=(neg?-1:1);
}
return num;
}
感谢。
答案 0 :(得分:0)
如果从右到左阅读字符串会更容易。你可以这样做:
/* decode. assume size(str) > 0 */
function (str,type) {
var len = size(str);
var num = str.charCodeAt(len - 1);
if (type.signed && (num >= 128)) {
num = num - 256;
}
for (var i = (len - 2); i >= 0; i--) {
num = 256 * num + str.charCodeAt(i);
}
return num;
}