js实现无符号整数按位取反方式

 更新时间:2026年03月16日 08:38:57   作者:攻城狮YanGo  
文章讨论了有符号和无符号整数的区别,以及如何在JavaScript中实现无符号整数的取反操作,通过一个简单的示例代码,展示了如何将0和1进行反转

前言

最近有一段时间没写文章了,工作上比较忙,刚好今天有人问到我这个问题,我就去补了一下功课。然后在js上实现了一下。

什么是无符号整数和有符号整数?

  • 有符号就是最高位是符号位,其余的位是数据位。
  • 无符号就是所有位都是数据位。

比如char类型是8位的,其中最高位是符号位1=0b00000000,-1=0b11111111(这里涉及到了补码),它能表示的范围是-128~+127。

unsigned char 是无符号字符型也是8位,它没有符号位,最高位是数据位,比如1=0b00000001,255=0b11111111,它的范围是0~255。

嗯,大概就是这么个意思了。

其实要实现的功能就是比如: 无符号整数取反

  • 0b00110100
  • 0b11001011

对比一下很明白吧!0和1反过来了。

要怎么实现呢

简单的处理方式,无非就是0变1,1变0嘛。

下面实现代码:

/**
 * @msg: 
 * @param {number,string} hex 十六进制数字或者字符
 * @param {string} len 位长度
 * @return {string} 返回十六进制字符
 */
function unsignedToReverse(hex,len){
  try{
    let bitArr;
    if(typeof hex === 'number'){
      bitArr = parseInt(hex);
    } else if(typeof hex === 'string'){
      bitArr = parseInt(hex,16);
    } else {
      console.error("hex参数有误")
      return;
    }
    bitArr = bitArr.toString(2).padStart(parseInt(len), "0").split('');
    let arr = [];
    // console.log(bitArr)
    bitArr.map((item,index) => {
      if(item == 1){
        arr[index] = 0
      } else if(item == 0){
        arr[index] = 1
      }
    })
    return "0x" + parseInt(arr.join(''),2).toString(16);
  } catch(err) {
    console.error("ERROR: %s",err)
  }
}

console.log(unsignedToReverse("0x38",8)) // 打印 0xc7

大概就这样子。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • bootstrap实现轮播图效果

    bootstrap实现轮播图效果

    这篇文章主要为大家详细介绍了bootstrap实现轮播图效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • js中关于一个分号的崩溃示例

    js中关于一个分号的崩溃示例

    下面的js代码不管if条件的结果是true还是false都会执行大括号的代码,结果发现if条件括号后面多写了分号,崩溃啊
    2013-11-11
  • 原生JS操作网页给p元素添加onclick事件及表格隔行变色

    原生JS操作网页给p元素添加onclick事件及表格隔行变色

    原生JS操作网页,给网页中的所有p元素添加onclick事件,使一个特定的表格隔行变色等等,感兴趣的朋友可以参考下
    2013-12-12
  • 使用typescript改造koa开发框架的实现

    使用typescript改造koa开发框架的实现

    这篇文章主要介绍了使用typescript改造koa开发框架的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • JavaScript 对引擎、运行时、调用堆栈的概述理解

    JavaScript 对引擎、运行时、调用堆栈的概述理解

    这篇文章旨在深入挖掘JavaScript,以及向大家解释JavaScript是如何工作的。非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-10-10
  • js使用正则表达式对身份证号的判断

    js使用正则表达式对身份证号的判断

    这篇文章主要给大家介绍了关于js使用正则表达式对身份证号的判断的相关资料,在用户注册页面有些需求要求的比较严格,需要对身份证验证是否合法,通过此功能严格此系统软件,从而过滤到很多,需要的朋友可以参考下
    2023-08-08
  • layui操作列按钮个数和文字颜色的判断实例

    layui操作列按钮个数和文字颜色的判断实例

    今天小编就为大家分享一篇layui操作列按钮个数和文字颜色的判断实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • Typescript学习之接口interface举例详解

    Typescript学习之接口interface举例详解

    TypeScript是JavaScript的一个超集,主要提供了类型系统和对ES6+的支持,TypeScript的核心原则之一是对值所具有的结构进行类型检查,这篇文章主要给大家介绍了关于Typescript学习之接口interface的相关资料,需要的朋友可以参考下
    2024-03-03
  • element-plus 官方表格排序问题小结

    element-plus 官方表格排序问题小结

    在使用Element Plus官方API时,表格默认排序可能会遇到问题,一个列表可能被多次排序影响数据展示,解决方法是修改useSortTable.js文件,这样可以确保表格按预期正确排序,更多详情可查阅相关的技术文档或资源
    2024-10-10
  • 使用ionic(选项卡栏tab) icon(图标) ionic上拉菜单(ActionSheet) 实现通讯录界面切换实例代码

    使用ionic(选项卡栏tab) icon(图标) ionic上拉菜单(ActionSheet) 实现通讯录界面切换实例

    这篇文章主要介绍了使用ionic(选项卡栏tab) icon(图标) ionic上拉菜单(ActionSheet) 实现通讯录界面切换实例代码,需要的朋友可以参考下
    2017-10-10

最新评论