位运算和反补原码及进制运算

嗯,昨天在复习java的时候遇到进制计算和反码补码原码的转换,脑子里没什么印象了,还是好记性不如烂笔头啊~

写在最前面的是几位大佬对这些东西的理解
_天行健反码补码原码原文链接
小猴子monkey1024位运算原文链接

位运算

位运算符:
& 位与
| 位或
^ 位异或
~ 取反
移位运算符:
>> 向右移
>>> 无符号右移
<< 向左移

位运算符都是操作的二进制

用法:
&,|,^,~ 的用法
&:有0则0
|:有1则1
^:相同则0,不同则1
~:按位取反

例子:

System.out.println(6 & 3);                //2
System.out.println(6 | 3);                //7
System.out.println(6 ^ 3);                //5    
System.out.println(~6);                    //-7?    

分析:
上面这些运算符会将数字转换成2进制再进行运算。6的二进制是110,3的二进制是011。根据上面的用法规则里面,列几个竖式:
例子1:
110
011
———–
010 &计算出十进制的2
例子2:
110
011
———–
111 |计算出十进制的7
例子3:
110
011
———–
101 ^计算出十进制的5
如果不了解原码反码补码的同学没有关系,这部分作为了解即可
00000000 00000000 00000000 00000110 6的原码反码补码都是本身
11111111 11111111 11111111 11111001 对6取反,得到-7的补码
00000000 00000000 00000000 00000001 补码减1
——————————————————————————
11111111 11111111 11111111 11111000 反码
10000000 00000000 00000000 00000111 原码(-7)
^的特点:一个数据对另一个数据位异或两次,该数本身不变。

例子:

System.out.println(5 ^ 10 ^ 5);
左移和右移
<<:左移    左边最高位丢弃,右边补齐0
>>:右移    最高位是0,左边补齐0;最高为是1,左边补齐1
>>>:无符号右移 无论最高位是0还是1,左边补齐0

例子:

    //右移,向右移动n位就是除以2的n次幂,向左移动n位就是乘以2的n次幂
    System.out.println(12 >> 1);
    System.out.println(12 >> 2);
    System.out.println(12 << 1);        //24
    System.out.println(12 << 2);        //48

进制运算

进制也就是进制位,对于接触过电脑的人来说应该都不陌生,我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。

进制运算
  • 二进制与十进制之间的转换

  • 十进制转二进制
    方法为:十进制数除2取余法,即十进制数除2,余数为权位上的数,得到的商值继续除2,依此步骤继续向下运算直到商为0为止。


    十进制转二进制
  • 二进制转十进制
    方法为:把二进制数按权展开、相加即得十进制数。


    二进制转十进制
  • 二进制与八进制之间的转换

  • 二进制转八进制
    方法为:3位二进制数按权展开相加得到1位八进制数。(注意事项,3位二进制转成八进制是从右到左开始转换,不足时补0)。


    二进制转八进制
  • 八进制转成二进制
    方法为:八进制数通过除2取余法,得到二进制数,对每个八进制为3个二进制,不足时在最左边补零。

反码补码原码

八进制转成二进制
  • 二进制与十六进制之间的转换

  • 二进制转十六进制
    方法为:与二进制转八进制方法近似,八进制是取三合一,十六进制是取四合一。(注意事项,4位二进制转成十六进制是从右到左开始转换,不足时补0)。


    二进制转十六进制
  • 十六进制转二进制
    方法为:十六进制数通过除2取余法,得到二进制数,对每个十六进制为4个二进制,不足时在最左边补零。


    十六进制转二进制
  • 十进制与八进制与十六进制之间的转换
    十进制转八进制或者十六进制有两种方法
    第一:间接法—把十进制转成二进制,然后再由二进制转成八进制或者十六进制。这里不再做图片用法解释。
    第二:直接法—把十进制转八进制或者十六进制按照除8或者16取余,直到商为0为止。

    十进制转八进制或者十六进制

  • 八进制或者十六进制转成十进制
    方法为:把八进制、十六进制数按权展开、相加即得十进制数。


    八进制或者十六进制转成十进制
  • 十六进制与八进制之间的转换
    八进制与十六进制之间的转换有两种方法
    第一种:他们之间的转换可以先转成二进制然后再相互转换。
    第二种:他们之间的转换可以先转成十进制然后再相互转换。

  • 原码是什么?

原码就是早期用来表示数字的一种方式: 一个正数,转换为二进制位就是这个正数的原码。负数的绝对值转换成二进制位然后在高位补1就是这个负数的原码

举例说明:
      int类型的 3 的原码是 11B(B表示二进制位), 在32位机器上占四个字节,那么高位补零就得:
      00000000 00000000 00000000 00000011
      int类型的 -3 的绝对值的二进制位就是上面的 11B 展开后高位补零就得:
      10000000 00000000 00000000 00000011   
   
但是原码有几个缺点,零分两种 +0 和 -0 。很奇怪是吧!还有,在进行不同符号的加法运算或者同符号的减法运算的时候,不能直接判断出结果的正负。你需要将两个值的绝对值进行比较,然后进行加减操作 ,最后符号位由绝对值大的决定。于是反码就产生了。

  • 反码是什么 ?
    正数的反码就是原码,负数的反码等于原码除符号位以外所有的位取反

举例说明:
      int类型的 3 的反码是
      00000000 00000000 00000000 00000011
      和原码一样没什么可说的
      int类型的 -3 的反码是
      11111111 11111111 11111111 11111100
      除开符号位 所有位 取反
      解决了加减运算的问题,但还是有正负零之分,然后就到补码了

  • 补码是什么?

正数的补码与原码相同,负数的补码为 其原码除符号位外所有位取反(得到反码了),然后最低位加1.

还是举例说明:
      int类型的 3 的补码是:
      00000000 00000000 00000000 00000011
      int类型的 -3 的补码是
      11111111 11111111 1111111 11111101
      就是其反码加1

最后总结一下:
1.正数的反码和补码都与原码相同。
2.负数的反码为对该数的原码除符号位外各位取反。
3.负数的补码为对该数的原码除符号位外各位取反,然后在最后一位加1

各自的优缺点:
1.原码最好理解了,但是加减法不够方便,还有两个零。
2.反码稍微困难一些,解决了加减法的问题,但还是有有个零。
3.补码理解困难,其他就没什么缺点了

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