位运算符最详细的解释(java)

2019-04-14 08:18发布

计算机中的数据都以二进制的形式存在,其中第一位作为我们的符号位,与数据共享一个存储空间,关于位运算符,呕心沥血,经过近两个小时的在纸上画写,终于有所感悟!!!!! 位运算右操作数要完成模32的运算,右移位运算右操作数要完成模32的运算,右移位运算右操作数要完成模32的运算,重要的事情说三遍!!! 简单来说也就是先将该数据转化为int(32位)在进行运算 "<<":左移位运算符,以0补全低位 byte a = -1; //1111 1111 1111 1111 1111 1111 1111 1111 System.out.println(a<<4); //1111 1111 1111 1111 1111 1111 1111 0000(补) //1000 0000 0000 0000 0000 0000 1001 0000(原) 输出结果:  -16 ">>":带符号右移位运算符,以符号为填充高位 byte a = -1; //1111 1111 1111 1111 1111 1111 1111 1111 System.out.println(a>>4);//以符号为1填充高位1111 1111 1111 1111 1111 1111 1111 1111(补) //1000 0000 0000 0000 0000 0000 0000 0001(原) 输出结果: -1 ">>>":无符号右移运算符,无视符号位,以0填充高位,无">>>"运算符的存在。 byte a = -1; //1111 1111 1111 1111 1111 1111 1111 1111 System.out.println(a>>4);//以0填充高位0000 1111 1111 1111 1111 1111 1111 1111 输出结果:   268435455