我是靠谱客的博主 无奈鸡翅,最近开发中收集的这篇文章主要介绍2.2 Go语言基础之位运算操作一、位运算符二、示例,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一、位运算符

位运算符对整数在内存中的二进制位进行操作。

运算符描述
&参与运算的两数各对应的二进位相与。 (两位均为1才为1)
|参与运算的两数各对应的二进位相或。 (两位有一个为1就为1)
^参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。 (两位不一样则为1)
<<左移n位就是乘以2的n次方。 “a<<b”是把a的各二进位全部左移b位,高位丢弃,低位补0。
>>右移n位就是除以2的n次方。 “a>>b”是把a的各二进位全部右移b位。

二、示例

2.1 &

参与运算的两数各对应的二进位相与。 (两位均为1才为1)

示例:

package main

import "fmt"

func main() {
    n1 := 13 //二进制为1101
    n2 := 3  //二进制为11
    //两个对应的二进制位都为1才为1
    fmt.Println(n1 & n2)
}

执行结果:

1555058991611

解释:

首先13二进制为1101,3二进制为11

1555059184594

因为两位均为1才为1,所以自右至左、自上而下:

1和1都为1,0和1其中一个为0不全为1所以为0,1和空不全为1所以为0,1和空不全为1所以为0,所以最终相与得0001转化为10进制为1

2.2 |

参与运算的两数各对应的二进位相或。 (两位有一个为1就为1)

示例:

package main

import "fmt"

func main() {
    n1 := 13 //二进制为1101
    n2 := 3  //二进制为11
    //两个对应的二进制位有1个为1就为1
    fmt.Println(n1 | n2)
}

执行结果:

1555059847238

解释:

1555059934368

因为两位有1个为1就为1,所以自右至左、自上而下:

1和1都为1,0和1有1个为1所以为1,1和空有1个为1所以为1,1和空有1个为1所以为1,所以最终相与得1111转化为10进制为15

2.3 ^

参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。 (两个对应的二进制位不一样则为1)

示例:

package main

import "fmt"

func main() {
    n1 := 13 //二进制为1101
    n2 := 3  //二进制为11
    //两个对应的二进制位不一样则为1
    fmt.Println(n1 ^ n2)
}

执行结果:

1555060251326

解释:

1555060320375

解释:

因为两位不一样就为1,所以自右至左、自上而下:

1和1两位一样所以为0,0和1两位不一样所以为1,1和空两位不一样所以为1,1和空两位不一样所以为1,所以最终相异或得1110转化为10进制为14

2.4 <<

左移n位就是乘以2的n次方。 “a<<b”是把a的各二进位全部左移b位,高位丢弃,低位补0。

注意:不论是左移还是右移,都是二进制位操作,我们这里的1也是二进制1

比如 1 << 10

具体操作原理如下:

1555061467099

根据原理计算方法:左移10位后,二进制为10000000000,转化为10进制为后为1024

套用公式计算方法:1*2^10=1024

代码示例:

package main

import "fmt"

func main() {
    fmt.Println(1 << 10)
}

执行结果:

1555061970948

巩固:

3 << 2

首先3的二进制为11,左移2位变成1100,然后将1100转换为10进制位12

代码示例:

package main

import "fmt"

func main() {
    fmt.Println(3 << 2)
}

执行结果:

1555062243954

2.5 >>

右移n位就是除以2的n次方。 “a>>b”是把a的各二进位全部右移b位。

注意:右移走的就相当于抛弃了,剩余的二级制位就是最终所得

例1:

3 >>1

答:

1555062434719

3的二进制为11,右移1位,1个1被右移了,相当于被抛弃了,剩余的1就是最终的二进制位。将其转换为10进制还是为1

例2:

3 >> 2

答:

1555062699845

3的二进制为11,右移1位,2个1被右移了,相当于被抛弃了,剩余的空(默认为0)就是最终的二进制位。将其转换为10进制还是为0

例3:

13 >>2

答:

1555062812756

13的二进制为1101,右移2位,0和1被右移了,相当于被抛弃了,剩余的11就是最终的二进制位。将其转换为10进制还是为3

代码示例验证:

package main

import "fmt"

func main() {
    fmt.Println(13 >> 2)
}

执行结果如下:

1555062906187

转载于:https://www.cnblogs.com/forever521Lee/p/10697603.html

最后

以上就是无奈鸡翅为你收集整理的2.2 Go语言基础之位运算操作一、位运算符二、示例的全部内容,希望文章能够帮你解决2.2 Go语言基础之位运算操作一、位运算符二、示例所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(32)

评论列表共有 0 条评论

立即
投稿
返回
顶部