Java 移位运算、符号位扩展】的更多相关文章

今天,魏屌出了一道题,题目如下: 定义一个大头序的byte[]a={-1,-2,-3,-4},转换成short[]b.问b[0]和b[1]分别是多少? 乍一看,这题不难,无非就是移位操作,再进行组合.但是呢?对于用Java的童鞋来说,这里面有一个坑,稍不注意可能就踩进去了.在说之前,我先把代码和答案贴出来吧. 看到这里,可能有的童鞋比较奇怪,为啥要&0xff,这不相当于没变化吗?非也,不信我举个例子. 答案是-127和129.很奇怪不是吗?我想的明明都是-127啊!!! 解答这个问题之前,我们先…
第一个例子: byte b=-100;b在内存中是以补码的形式存贮的:1001 1100 如果执行char c=(char)b;如3楼企鹅先生所说:b要先变为int,这时增加的位全要用b的符号位填充(这就是符号扩展),变为:1111 1111 1111 1111 1111 1111 1001 1100 下步是强制类型转换,只保留了最低的两个字节:1111 1111 1001 1100. 如果执行char c=(char)(b&0xff),同样b要转为int ,同时符号位扩展:1111 1111 …
一.java按位运算符(操作符) 这段时间偶尔看一下源码,会发现有很多很基础的java知识在脑海中已经慢慢的淡成不常用记忆,于是打算捡起来一些. 按位运算符是来操作整数基本数据类型中的单个“比特”(bir),即二进制位,位运算符会对两个参数中对应的位执行布尔代数运算,并最终生成一个结果. 位运算符来源于C语言面向底层的操作,在这种操作中经常需要直接操作硬件,设置硬件寄存器内的二进制位.Java的设计初衷是为了嵌入电视机机顶盒,所以种面向底层的操作仍被保留了下来. 1.“与”.“位与”(&) 按位…
类型取值范围 short 是1字节,即8位.而且 Java 中只有有符号数,所以最大值 0111,1111=2^7-1. 同时计算机中以补码形式存负数,所以可以多表示一个数,则最小值 1000,0000=-2^7=-128. [因为原码中有 +0 -0,所以反码也一样] 图源 那么如果我传入的 byte 超过最大值 127 呢? byte a = (byte)234; System.out.println(a); // 输出-22 234原码: 11101010,因为 byte 高位为符号位,所…
一.背景知识 整数在内存中是以二进制的形式存在的,而且存的是该整数的补码.最高位代表符号位,正数为0,负数为1 正数的补码是其二进制本身,负数的补码则是 符号位保持1不变,其他位按位取反再加1,+0和-0的补码相同,都是0. 负数在进行按位与运算时是以补码形式参与运算.(这个很好理解,因为负数在内存中本身就是以补码存储的) 二.移位运算 下面介绍三种移位运算, 首先我们对5作运算. 5在内存中的存储形式为:0000 0000 0000 0000 0000 0000 0000 0101 1.左移<…
java中移位运算符有三种“<<”.“>>”.“>>>”,没有“<<<”运算符. “<<”运算符将二进制位进行左移,低位用0来填充: “>>”运算符将二进制位进行右移,用符号位填充高位: “>>>”运算符将二进制位进行右移,但是是用0来填充高位. 注意:对移位运算符右侧的参数需要进行模32的运算,如,1<<35与1<<3是相同的,都为8. (当左侧的操作数是long类型时,右侧操作…
学习移位运算,首先得知道参与移位运算的类型的位数,那先来复习下Java基础类型的占位数吧. Java基础类型 Java基础类型总结一览表 类型 二进制位数 最大值 最小值 初始化值 表示形式 带符号 char 8 127(2^7-1) -128(-2^7) 0 二进制补码 是 short 16 32767(2^15 - 1) -32768(-2^15) 0 二进制补码 是 int 32 2,147,485,647(2^31 - 1) -2,147,483,648(-2^31) 0 二进制补码 l…
运算符(java) 算数运算符:+,-,*,/,%(取余),++,-- 赋值运算符:= 关系运算符:<, >, >= ,<= ,== , != 逻辑运算符:&&,||,! 位运算符:&,|,^,~,>>,<< 条件运算符:?,: 扩展赋值运算符:+=,-=,*=,/= public class Demo01 {    public static void main(String[] args) {        // 二元运算符  …
移位运算 :将整数转化为二进制(以补码的形式),按位平移. <<     左移 >>     右移 >>>   无符号右移 << 右移: 按位做平移,末位用0补上(正负数都一样) a << n; 如果 a 是  byte.short.int 类型 那么 a << n 就是  a << (n%32) int a = 5; System.out.println(a<<3);     //输出 40 Syste…
版权声明:本文为博主原创文章,未经博主允许不得转载. 首先,介绍一下两种扩展的定义 转 http://blog.csdn.net/jaylong35/article/details/6160736 符号扩展:当用更多的内存存储某一个有符号数时,由于符号位位于该数的第一位,扩展之后,符号位仍然需要位于第一位,所以,当扩展一个负数的时候需要将扩展的高位全赋为1.对于正数而言,符号扩展和零扩展是一样的,因为符号位就是0. 比如一个用一个8位二进制表示-1,则是10000001 如果把这个书用16位二进…