zoukankan      html  css  js  c++  java
  • 如何计算位运算中的左移和右移

    正数的左移和右移
    以3为例
    3的二进制为
    00000011
    右移2位的时候将最右的11去掉左边补00结果为:00000000 — >十进是中的0
    左移2位的时候将最左的00去掉右边补00结果为:00001100 —–>十进是中的12

    对于-3来说,负数的都是以补码的形式存在于计算器中
    补码 = 反码+1
    -3的二进制为
    100000011
    取反的补码为(符号为不变)
    111111100
    再加1,为补码11111101

    右移2位的时候将最右的01去掉左边补11结果为:11111111 —> 为补码,要求原码
    还需要-1 :11111110 ,再取反(符号位不动) :10000001:——>十进制中的-1,所以-3的右移2位为十进制中的-1

    左移2位的时候将最左边11去掉右边补00结果为:11110100 —-> 为补码,要求原码

    以上都是我日常工作的学习与总结,希望知识能积少成多,以后的我一定会感激现在努力的自己。。
  • 相关阅读:
    spring
    抽象和封装
    Oracle索引的原理
    使用JdbcTemplate.queryForObject 的注意点
    ORM是什么意思
    Java 后台处理数据库的二进制图片流
    Extjs girdPanel显示图片
    斜率dp
    多重背包的二进制优化
    POJ 3249 DAG图最短路
  • 原文地址:https://www.cnblogs.com/zaochajun/p/13186579.html
Copyright © 2011-2022 走看看