位运算符补充

位运算符

按位取反:1变成0,0变成1

按位与:每位都是1,结果才为1

按位或:每位只要有一个是1,结果就是1

异或:不同为1,相同为0

清除标志位:右侧数字的位上为1,清0,否则不清零

位左移:每左移一位扩大2倍

位右移:每右移一位除以2

func main() {
    a,b:=5,6                //101   110
    fmt.Println(^a)         //按位取反  -6
    fmt.Println(a&b)        //按位与   4
    fmt.Println(a|b)        //按位或   7
    fmt.Println(a^b)        //异或        3
    fmt.Println(a&^b)       //右侧1表示清零       清除标志位
    fmt.Println(a<<1)       //10  相当于乘以2
    fmt.Println(a>>1)       //2   相当于除以2
} 

思考:如下代码输出什么?

//练习一
const(
    num1 int=1<<(iota*10)
    num2
)
func main(){
    fmt.Println(num1)   //1
    fmt.Println(num2)   //1024
}

//练习二
const(
    num1 int=10
    num2 ="tom"
    num3 int=1<<(iota*2)
)
func main(){
    fmt.Println(num1)       //10
    fmt.Println(num2)       //tom
    fmt.Println(num3)       //16
}

原码、反码、补码

正数的原码,反码,补码都是一样的。

负数的反码 = 原码的符号位不变,其他的位取反【最高位为符号位:正数为0,负数为1】

负数的补码 = 反码 + 1

5的原码=0101     反码=0101   补码=0101
-5的原码1101     反码=1010   补码=1011

[7]原码=0111     [7]反=0111   [7]补码=0111
[-7]原码=1111     [-7]反=1000 [-7]补码=1001

分析:为什么^5=-6

第一步:将5转成原码  = 0101
第二步:原码转成补码 =0101   (正数的原、反、补是一样的)
第三步:取反:      =1010    (补码运算)
第四步:将补码转成反码:1010-1=1001  (反码)
第五步:将反码转成原码:1110 =-6

为什么使用补码计算机

1、 +0和-0表示方法一样

2、 利用高位溢出,将减法运算变成加法运算(利用补码运算可以将符号位参与运算)

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 概述 在学习位运算之前,先说下几个概念: 机器数:一个数字在计算机中的二进制表达形式就叫做机器数。机器数是有符号位...
    骑着乌龟去看海阅读 2,466评论 1 4
  • 「WTF系列」深入Java中的位操作 关于WTF系列 引 学完本章节你将学会位的基础概念与语法,并且还会一些骚操作...
    qiujuer阅读 928评论 0 5
  • 进制基本概念 什么是进制?进制是一种计数的方式,数值的表示形式 常见的进制十进制、二进制、八进制、十六进制 进制书...
    极客江南阅读 2,050评论 0 11
  • 奕宣2019年2月20日感恩日志:1、感恩父母的养育之恩,公公婆婆对我照顾,天地的庇佑; 2.感恩董事长搭建的平台...
    李奕宣阅读 243评论 1 1
  • 1 朋友圈里有篇“远离垃圾人”的文章,用犀利的文字指出种种招惹疯狗后不堪设想的后果,最后得出远离的结论,不要和这种...
    余应心阅读 121评论 0 0