|
@@ -24,6 +24,31 @@
|
|
|
|
|
|
  根据我的粗俗理解,缝合一下理论就是,无符号数将会在数据前面用一位来专门表示正数还是负数.所以`n`位的无符号数能表示的最大正整数值`y`为
|
|
|
$y=2^n/2-1$
|
|
|
-根据该公式发现无符号数的最大值只有位数的一半还要少1。有一半空间用来存储负整数。
|
|
|
+根据该公式发现无符号数的最大值只有位数的一半还要少1。有一半空间用来存储负整数。比如16位有符号数,可以表示`-32768~32767`之间的任意整数,如果是16位无符号数可以表示`0~65535`之间的整数。例如,在16位有符号数中,`0xFFFF`表示`-1`,但在16位无符号数中`0xFFFF`表示`65535`,可以依次获取-2,以及-3的值,发现可以使用目标位数的最大值来减去目标值来获取一个负数的16进制值。参考[无符号数wiki](https://zh.wikipedia.org/wiki/%E6%97%A0%E7%AC%A6%E5%8F%B7%E6%95%B0)
|
|
|
+  那么:2的16次方为65536,最大的负整数数从-1开始.那么可以通过65536来加上负数来得到对应的无符号数的10进制值.
|
|
|
+  例如:在16位有符号数中的-1,转换为16进制值. 65536+(-1) = 65535 将65535转换为16进制值可以得到 `0xFFFF`
|
|
|
+3. **具体代码**
|
|
|
+根据上方分析可以获取一个函数
|
|
|
+<!-- tabs:start -->
|
|
|
+#### **易读版本**
|
|
|
|
|
|
+```javascript
|
|
|
+function toHex(n,number){
|
|
|
+ if(number<0){
|
|
|
+ // 如果是负数则获取指定位数n的最大位数的值(比可表示数的最大值还要多1),因为0不算是负数所以可以直接拿理论最大值去减
|
|
|
+ let tmpNumber = Math.pow(2,n) + number
|
|
|
+ return tmpNumber.toString(16)
|
|
|
+ }else{
|
|
|
+ // 如果当前数为正数则直接调用正常的转16进制逻辑
|
|
|
+ return number.toString(16)
|
|
|
+ }
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### **爽就完事版本**
|
|
|
+
|
|
|
+```javascript
|
|
|
+function toHex(n,number){return (number<0?Math.pow(2,n)+number:number).toString(16)}
|
|
|
+```
|
|
|
|
|
|
+<!-- tabs:end -->
|