摘要:進制轉換在線工具獲取的高位和低位獲取高四位獲取低四位高位和低位合并字節(jié)高位空格低位例如二進制轉換成進制二進制轉換十六進制十六進制字符串轉字節(jié)數組十六進制字符串轉字節(jié)數組每個字符串轉換轉為符合進制字符串字節(jié)數組轉十六進制字符串字節(jié)數組轉
進制轉換在線工具
獲取byte的高4位bit和低4位bit
function getHeight4(ata){//獲取高四位 int height; height = ((data & 0xf0) >> 4); return height; } function getLow4(data){//獲取低四位 int low; low = (data & 0x0f); return low; }
高4位和低4位合并
1字節(jié) = 高4位(空格)低4位 例如:00001001 = 0000 1001 二進制轉換成16進制 1001(二進制) 轉換 0x09(十六進制)
十六進制字符串轉字節(jié)數組
/** * 十六進制字符串轉字節(jié)數組 * 每2個字符串轉換 * 903132333435363738 轉為 [-112, 49, 50, 51, 52, 53, 54, 55, 56] * @param {String} str 符合16進制字符串 */ Str2Bytes(str) { var pos = 0; var len = str.length; if (len % 2 != 0) { return null; } len /= 2; var hexA = new Array(); for (var i = 0; i < len; i++) { var s = str.substr(pos, 2); var v = parseInt(s, 16); if(v >=127) v = v-255-1 hexA.push(v); pos += 2; } return hexA; },
字節(jié)數組轉十六進制字符串
/** * 字節(jié)數組轉十六進制字符串 * [-112, 49, 50, 51, 52, 53, 54, 55, 56] 轉換 903132333435363738 * @param {Array} arr 符合16進制數組 */ Bytes2Str(arr) { var str = ""; for (var i = 0; i < arr.length; i++) { var tmp; var num=arr[i]; ????if (num < 0) { ????//此處填坑,當byte因為符合位導致數值為負時候,需要對數據進行處理 ??????tmp =(255+num+1).toString(16); ????} else { ??????tmp = num.toString(16); ????} if (tmp.length == 1) { tmp = "0" + tmp; } str += tmp; } return str; },
十六進制字符串轉數組
/** * 十六進制字符串轉數組 * 1185759ac35a91143f97037002b1a266 轉換 ["11", "85", "75", "9a", "c3", "5a", "91", "14", "3f", "97", "03", "70", "02", "b1", "a2", "66"] * @param {String} str 十六進制字符串 */ Str2Arr(str) { var pos = 0; var len = str.length; if (len % 2 != 0) { return null; } len /= 2; var hexA = new Array(); for (var i = 0; i < len; i++) { var s = str.substr(pos, 2); hexA.push(s); pos += 2; } return hexA; },
十六進制數組進行異或
/** * 十六進制數組進行異或 * @param {Array} arr 十六進制數組 */ BytesDes(arr) { var des = 0 for (var i = 0; i < arr.length; i++) { des ^= parseInt(arr[i], 16) } return des.toString(16).toUpperCase(); },
十進制轉十六進制
/** * 十進制轉十六進制 * 15 轉 0F * @param {Number} num 十進制數字 */ toHex(num) { return ("0" + (Number(num).toString(16))).slice(-2).toUpperCase() }
二進制轉十六進制
/** * 二進制轉十六進制 * 00001001 轉 09 * @param {String} str 二進制字符串 */ binTohex(str) { let hex_array = [{ key: 0, val: "0000" }, { key: 1, val: "0001" }, { key: 2, val: "0010" }, { key: 3, val: "0011" }, { key: 4, val: "0100" }, { key: 5, val: "0101" }, { key: 6, val: "0110" }, { key: 7, val: "0111" }, { key: 8, val: "1000" }, { key: 9, val: "1001" }, { key: "a", val: "1010" }, { key: "b", val: "1011" }, { key: "c", val: "1100" }, { key: "d", val: "1101" }, { key: "e", val: "1110" }, { key: "f", val: "1111" }] let value = "" let list = [] if (str.length % 4 !== 0) { let a = "0000" let b = a.substring(0, 4 - str.length % 4) str = b.concat(str) } while (str.length > 4) { list.push(str.substring(0, 4)) str = str.substring(4); } list.push(str) for (let i = 0; i < list.length; i++) { for (let j = 0; j < hex_array.length; j++) { if (list[i] == hex_array[j].val) { value = value.concat(hex_array[j].key) break } } } return value }
十六進制數字和ASCII字符之間轉換
var hex="0x10";//十六進制 var charValue = String.fromCharCode(hex);//生成Unicode字符 var charCode = charValue.charCodeAt(0);//獲取指定字符的十進制表示. var hexOri="0x"+charCode.toString(16);;//將int值轉換為十六進制 hex:0x10 charValue:+ charCode:16 hexOri:0x10
十六進制數組轉ASCLL編碼
/** * 十六進制字符串轉ASCLL編碼 * 3132333435363738 轉換 12345678 * @param {String} str 十六進制字符串 */ HexToAscll(str) { var pos = 0; var len = str.length/2; var hexA = ""; for (var i = 0; i < len; i++) { var s = str.substr(pos, 2); hexA += String.fromCharCode(`0x${s}`); pos += 2; } return hexA; },
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/103865.html
摘要:學習筆記字符串的擴展字符的表示法允許使用的形式表示一個字符,但在之前,單個碼點僅支持到,超出該范圍的必須用雙字節(jié)形式表示,否則會解析錯誤。返回布爾值,表示參數字符串是否在源字符串的頭部。,是引入了字符串補全長度的功能。 es6學習筆記-字符串的擴展_v1.0 字符的Unicode表示法 JavaScript 允許使用uxxxx的形式表示一個字符,但在 ES6 之前,單個碼點僅支持u00...
摘要:此類中的方法在關閉此流后仍可被調用,而不會產生任何。主要的功能是從緩沖區(qū)讀取字節(jié)構造函數創(chuàng)建一個,使用作為其緩沖區(qū)數組。緩沖區(qū)會隨著數據的不斷寫入而自動增長。 內存操作流 之前的所有的流操作都是針對文件的,但是有時候只是想要實現數據間轉換,此時如果我們想要創(chuàng)建一個文件然后再刪除文件,那樣顯得有點麻煩,因此此時的內存操作流就顯得很適合這類的操作,因為它只是在內存中存儲,并不會真正的創(chuàng)建文...
摘要:而所有的數據運算都是采用補碼進行的。補碼解決負數加法運算正負零問題,彌補了反碼的不足。通過使用訪問修飾符可以使實例變量對子類可見暫時在學習基礎語法知識的時候可以暫時忽略實例變量這部分內容,這部分內容主要被使用在面向對象的部分,但是極其重要。 showImg(https://segmentfault.com/img/remote/1460000019264541?w=600&h=242)...
閱讀 1452·2023-04-25 19:00
閱讀 4150·2021-11-17 17:00
閱讀 1764·2021-11-11 16:55
閱讀 1523·2021-10-14 09:43
閱讀 3120·2021-09-30 09:58
閱讀 856·2021-09-02 15:11
閱讀 2127·2019-08-30 12:56
閱讀 1405·2019-08-30 11:12