位运算基础知识
admin
2024-03-28 01:59:16
0

位运算基础知识

  1. 按位与 &

    • 11 得 1,10、01、00 得 0
    • 有 0 就得 1
  2. 按位或 |

    • 00 得 0, 10、11、01 和 11 得 1
    • 有 1 就得 1
  3. 异或 ^

    • 相同得 0,不同得 1
  4. 取反 ~

  5. 左移 <<

  6. 有符号右移 >>

  7. 无符号右移 >>>

整数

整数一般用补码来表示

  • 有符号整数,即最高位为符号位:
    1. 0000 1010 正数
    2. 1000 1010 负数
  • 整数类型: byte(8 位)、short(16 位)、init(32 位)、long(64 位)
  1. 有符号整数

    最高位是整数类型 8、16、32、64 位的欧式有符号整数。

  2. 无符号整数
    如果最高位表示的不是整数类型就是无符号整数。

  3. 原码、反码、补码

    1. 10 -> 32 位
    2. 原码是 00000000 00000000 00000000 00001010
    3. -10 的原码 10000000 00000000 00000000 00001010
    4. 反码: 符号为不变,其他位取反.
      1. 10 的反码:01111111 1111111 1111111 11110101
      2. -10 的反码:11111111 1111111 1111111 11110101
    5. 正整数的补码 === 原码
    6. 负整数的补码 === 反码 + 1
      • 负整数用补码表示
      • 反码 + 1

有符号整数的二进制规律

  1. 4 位 [-8, 7] === [-2^3, 2^3 - 1]

    • 0000 : 0
    • 0001 : 1
    • 0010 : 2
    • 0011 : 3
    • .
    • .
    • .
    • 1000 : -8
      1. 1 是符号位,说明是负数。
      2. 减 1 取反码得 1111
      3. 取原码得 1000 得 8,符号位是 1,所以是 -8
    • 1001 : -7
    • 1111 : -1
  2. 8 位 [-32, 31] === [-2^7, 2^7 - 1]

  3. 32 位 [-2^31, 2^31 - 1]

按位取反

~ 9 = -10

  1. 9 的原码: 1001
  2. 9 的补码: 01001
  3. 取反: 10110 ->
  4. 10110 减 1,取反得原码:11010
  5. 11010 十进制得 -10

左移 << 有符号右移 >> 无符号右移 >>>

  1. 左移:和符号没有关系
    • 4: 0000 0000 0000 0000 0000 0000 0000 0100
    • 4 <<2: 0000 0000 0000 0000 0000 0000 0001 0000 得 16
    • -4 取补码 1111 1111 1111 1111 1111 1111 1111 1100
    • -4<<2 1111 1111 1111 1111 1111 1111 1111 0000
      • 减 1: 1111 1111 1111 1111 1111 1111 1110 1111
      • 取反 0000 0000 0000 0000 0000 0000 0001 0000 得 -16
  2. 有符号右移:高位补 1
    1. 正数:数的有符号右移和有符号右移是一样的
      • 15: 0000 0000 0000 0000 0000 0000 0000 1111
      • 15>>2: 0000 0000 0000 0000 0000 0000 0000 0011
      • 15>>>2: 0000 0000 0000 0000 0000 0000 0000 0011
    2. 负数:
      • -15: 补码: 1111 1111 1111 1111 1111 1111 1111 0001
      • -15>>2: 11 1111 1111 1111 1111 1111 1100 (高位补 1)得: 1111 1111 1111 1111 1111 1111 1111 1100
      • 减 1: 1111 1111 1111 1111 1111 1111 1111 1011
      • 取反:1000 0000 0000 0000 0000 0000 0000 0100
      • 得 -4
  3. 无符号右移:高位补 0
    • -15: 补码: 1111 1111 1111 1111 1111 1111 1111 0001
    • -15>>>2: 0011 1111 1111 1111 1111 1111 1100 (高位补)得 1111 1111 1111 1111 1111 1111 1111 1100
    • 符号位为 0,是正数,当成原码来算
    • 1073741820

相关内容

热门资讯

原创 真... 乔布斯曾讲过一个企业的底层逻辑:如果你在顶层做了正确的事,底层的结果就会随之而来。 人们关注企业每年...
国内成品油价今晚上涨,加满一箱... 界面新闻记者 | 田鹤琪 国内成品油价迎来“三连涨”。 2月24日,国家发改委发布消息称,自24时...
马斯克设想从月球电磁弹射AI卫... IT之家 2 月 25 日消息,据新华社报道,为更便捷部署专用于人工智能 (AI) 的数据中心卫星网...
马年首涨:中概股破局,A股引领... 在黄金因美元强势而黯然跳水、A股于春节后首个交易日释放出久违的磅礴巨量之际,大洋彼岸的美股市场,第一...
原创 帮... 昨晚大宗商品市场,走出一场“分道扬镳”的戏码。 原油连续第三天下跌,WTI跌破66美元,布伦特收在7...
今起可预约!办理2025年度个... 今起可预约!办理2025年度个税汇算 这些事项要注意 2026-02-25 06:54:50 看看...
原创 天... 年后的天津二手房,马上就要起跑了。 其实在1月份迹象就已显现。 往年的楼市淡季却“反常”得活跃:连续...
13F机构追踪:谷歌、拼多多、... 来源:活报告 在美股市场,资产管理规模超过1亿美元的机构需要在每个季度结束后的45天内向SEC提交1...
原创 手... 最近一段时间,有个词突然走红甚至冲上热搜,这就是手搓经济,在这个早已经现代工业化的时代,手搓经济是怎...
【美联储理事警告:美联储货币政... 【美联储理事警告:美联储货币政策可能无法应对AI引发的失业潮 】库克称,AI已引发美国劳动力市场的代...
黄金和交易提醒:金价高位“吞没... 来源:市场资讯 文章来源:汇通财经 周三(2月26日)亚市早盘,现货黄金窄幅震荡,目前交投于5150...
IPO雷达| 百普赛斯港股IP... 百普赛斯(301080.SZ)正式向香港联交所递交招股书。根据公司同步发布的2025年度业绩预告,全...
原创 澳... 2025年一则“澳洲高薪挖角中国稀土团队”的新闻,把全球稀土市场搅得风生水起。澳大利亚莱纳斯公司甩出...
苹果收购单人AI初创公司inv... IT之家 2 月 25 日消息,据 MacRumors 报道,一份提交给欧盟的新文件显示,苹果公司已...
珍惜:由早晨跑步所想到的 我每天早晨起来习惯在校园跑步,在跑步的时候,常常会思考跑步、人生及享受人生之间的关系。 我们知道人的...
趁乱抛售?最高法院刚裁决,对冲... 来源:市场资讯 来源:金十数据 根据外媒获得的一份美国银行报告,花旗的对冲基金客户在上周五美国最高法...
特别关注|9艘!“超高规格”新... 根据广船国际官微介绍,上述MR型油轮新造船为广船国际自主设计,总长约183米、宽32.2米,设计服务...
甲骨文股价在星门项目相关报道发... 来源:环球市场播报 周一, 甲骨文股价下跌4.5%,此前报道称,这家云计算公司与OpenAI和软银的...