位运算符

一、 常见位运算符

运算符 运算 范例
<< 左移 3 << 2 = 12 -> 3 * 2 * 2 = 12
>> 右移 3 >> 1 = 1 -> 3 / 2 = 1
>>> 无符号右移 3 >>> 1 = -1 -> 3/2 = 1
& 与运算 6 & 3 = 2
| 或运算 6 | 3 = 7
^ 异或运算 6 ^ 3 = 5
~ 取反运算 ~6 = -7
  • 位运算是直接对整数的二进制进行的运算
  • 没有<<< 无符号左移

二、左移举例

21(十进制整数)

21 << 2 = ?

首先将21转换位二进制

10101 向左移两位,空出位置补0 于是变成了

1010100 转为十进制:1 * 22 + 1 * 24 + 1 * 26 = 84

所以 21 << 2 = 84

总结:每向左移一位相当于在原来数上的基础乘以2,即 21 * 2n,n为向左移位数

举例说明:

10101 = 1 * 20 + 1 * 22 + 1 * 24

  • 左移一位实际上为 1 * 21 * (1 * 20 + 1 * 22 + 1 * 24 )

    转换为十进制的乘法即为 21 * 21 = 21 * 2 = 42

    等同于1 * 2 * (1 * 20 + 1 * 22 + 1 * 24 ) => 21 * 2 = 21 * 2 = 42

  • 左移两位实际上为 1 * 22 * (1 * 20 + 1 * 22 + 1 * 24 )

    转换为十进制的乘法即为 21 * 22 = 21 * 4 = 84

    等同于 1 * 2 * 2 * (1 * 20 + 1 * 22 + 1 * 24 ) => 21 * 2 * 2 => 21 * 4 = 84

  • 左移三位实际上为 1 * 23 * (1 * 20 + 1 * 22 + 1 * 24 )

    转换为十进制的乘法即为 21 * 23 = 21 * 8 = 168

    等同于 1 * 2 * 2 *2 * (1 * 20 + 1 * 22 + 1 * 24 ) => 21 * 2 * 2 * 2=> 21 * 8 = 168

三、右移举例

21(十进制整数)

21 >> 2 = ?

首先将21转换位二进制

10101向右移两位,前方位置补零于是变成了

00101 转为十进制:1 * 20 + 1 * 22= 5

所以 21 >> 2 = 5

总结:每向右移一位相当于在原来数上的基础除以2,即 21 / 2n,n为向右移位数

推导过程:

10101 = 1 * 20 + 1 * 22 + 1 * 24

  • 右移一位实际上为 (1 * 21 ) / (1 * 20 + 1 * 22 + 1 * 24 )

    转换为十进制的乘法即为 21 / 21 = 21 / 2 = 10

    等同于(1 * 2) / (1 * 20 + 1 * 22 + 1 * 24 ) => 21 / 2 = 21 / 2 = 10

  • 左移两位实际上为 (1 * 22) / (1 * 20 + 1 * 22 + 1 * 24 )

    转换为十进制的乘法即为 21 / 22 = 21 / 4 = 5

    等同于 (1 * 2 * 2) / (1 * 20 + 1 * 22 + 1 * 24 ) => 21 / (2 * 2) => 21 / 4 = 5

  • 左移三位实际上为 (1 * 23) / (1 * 20 + 1 * 22 + 1 * 24 )

    转换为十进制的乘法即为 21 / 23 = 21 / 8 = 2

    等同于 (1 * 2 * 2 *2) / (1 * 20 + 1 * 22 + 1 * 24 ) => 21 / (2 * 2 * 2)=> 21 / 8 = 2

四、总结

位运算符的效率高于算术运算符。

经典面试题:

最高效的方式计算 2 * 8 ?

答: 2 << 3 或 8 << 1

五、位运算符的细节

<< 空位补0,被移除的高位丢弃,空缺为补0
>> 被移位的二进制位是0,右移后,空缺位0;最高位是1,空缺为补1。
>>> 被移位二进制最高位无论是0或者是1,空缺位都用0补。
& 二进制位进行&运算,只有 1 & 1时结果是1,否则是0;
| 二进制位进行 | 运算,只有 0 | 0 时结果是0,否则是1;
^ 相同的二进制位进行^运算,结果是0;1 ^ 1 = 0 ,0 ^ 0 = 0 不相同的二进制位 ^ 运算结果是1。1 ^ 0 = 1 ,0 ^ 1 = 1
~ 正数取反,各二进制码按补码各位取反;负数取反,各二进制码按补码各位取反

六、其他运算符的举例

6.1 &(与)运算符

12 & 5 = 4

过程

12 => 1100(二进制)

5 => 0101(二进制)

比较过程:

0 & 1 = 0; 0 & 0 = 0 ; 1 & 1 = 1; 1 & 0 = 0

&运算符.png

结果为 0100(二进制) => 4 (十进制)

总结:只有当比较双方都为1时,结果才为1,,否则为0

6.2 |(或)运算符

12 | 5 = 4

过程

12 => 1100(二进制)

5 => 0101(二进制)

比较过程:

0 | 1 = 1; 0 & 0 = 0 ; 1 & 1 = 1; 1 & 0 = 1

|运算符.png

结果为: 1101(二进制) => 13(十进制)

总结:当比较双方只要有一个为1,那么其值为1,否则为0

6.3 ^(异或)运算符

12 ^ 5 = 4

过程

12 => 1100(二进制)

5 => 0101(二进制)

比较过程:

0 ^ 1 = 1; 0 ^ 0 = 0 ; 1 ^ 1 = 0; 1 ^ 0 = 1


^运算符.png

结果为:1001(二进制) => 9 (十进制)

总结:当比较双方都为异(值不同)时,才等于1,否则为0

6.4 ~(取反)运算符

~6 = -1

过程

6 => 0110(二进制)

包括符号位在内的所有数取反

即变为1001 => -7

注意:要将二进制码转换为补码才能进行取反,取反包括符号位

图片部分来自网络引用,如有侵犯请联系作者删除

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 222,729评论 6 517
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 95,226评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 169,461评论 0 362
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 60,135评论 1 300
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 69,130评论 6 398
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,736评论 1 312
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,179评论 3 422
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,124评论 0 277
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,657评论 1 320
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,723评论 3 342
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,872评论 1 353
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,533评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,213评论 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,700评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,819评论 1 274
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 49,304评论 3 379
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,876评论 2 361