位运算Java攻城狮的入门课程Java学习笔记

(二)位运算

2017-02-21  本文已影响142人  黒猫

1、位运算符

用来操作二进制位。

与 | 或 | 异或| 取反 | 左移| 右移 | 无符号右移
----|------|----
& ||| ^ |~ | <<| >> |>>>


以下出现的二进制中的1,0分别代表TRUE(真)和FALSE(假),便于总结。

2、按位与运算:都真则真,一假则假

例:计算6&4,结果为4。
  首先分别写出十进制数6,4的二进制数;其次按照十进制加法的形式从上到下对应位数去看,最左侧都为0,中间是1和0,所得结果为0,0代表FALSE(假),因此只要有一个为0,结果就是0,即一假则假;最右侧都为1,1代表TRUE(真),因此只有全为1,结果才为1,即都真则真。

其后的按位或等其他运算就不详细展开叙述,原理相通,只写出总结。

按位与的特殊用法

1. 清零。
如果要使一个二进制数的全部二进制位等于0,只要同一个各位都为0的二进制数相与即可。
2. 求任意二进制数的指定位。
例:设x=1010 1110,要求x的 低四位,结果为0000 1110。
方法如下:设另一个二进制数y,y对应x要求的数位为1,其余位为0,可得y=0000 1111,之后用x&y,可得结果0000 1110。


3、按位或运算:一真则真,都假则假

例:计算7|3,结果为7。

按位或的特殊用法

对任意二进制数的指定位置1。
例:设x=1010 0000,要求将x的 低四位置1,结果为1010 1111。
方法如下:设另一个二进制数y,y对应x要求的数位为1,其余位为0,可得y=0000 1111,之后用x|y,可得结果1010 1111。


4、按位异或运算:不同为真,相同为假

例:计算7^3,结果为3。

按位异或的特殊用法

1. 用于加密。
一个数,异或同一个数两次,结果是这个数本身,可用于加密。
例:744=7。
2. 与0异或,保留原值。
例:7^0=7。
3. 交换变量值。
利用一个数异或本身等于0以及异或运算符合交换律的原理实现。
例:交换a,b两个变量的值。

  int a = 7;
  int b = 3;
  a=a^b;//此时a=4
  b=a^b;//此时b=7
  a=a^b;//此时a=3,已完成交换

4. 使任意二进制数的指定位翻转。
例:设x=1010 1110,要使x的 低四位翻转,结果为1010 0001。
方法如下:设另一个二进制数y,y对应x要求的数位为1,其余位为0,可得y=0000 1111,之后用x^y,可得结果1010 0001。


5、按位取反运算

例:计算~7,结果为-8。
参考进制转换,简单理解:

原码+补码=0;//原码与补码互为相反数,7的补码为-7
反码=补码-1;//补码为反码加一所得,-7-1=-8

6、左移运算

例:计算6向左移动2位,结果为24。
方法如下:6<<2相当于6x2²;左移扩大,移动几位,就让要计算的数乘以2的几次幂。

左移运算的特殊用法

最有效率。
例:使用最有效率的方法计算2乘以8,结果为2<<3。
方法如下:二进制方法最有效率,因此2x8可看做2x2³,即2左移3位。


7、右移运算

例:计算6向右移动2位,结果为1。
方法如下:6>>2相当于6/2²;右移缩小,移动几位,就让要计算的数除以2的几次幂。

右移运算的特殊用法

最有效率。


8、无符号右移运算

例:计算-6>>>2,结果是1073741822。
方法如下:首先写出-6的二进制形式,并向右移动2位,缺失的2位用0补充,整理后按照进制转换中二进制数转十进制数的方法,进行计算。

1.无符号右移与有符号右移的区别

例:计算-6>>2,结果是-2。


有符号右移:高位原本是1就补1,原本是0就补0;
无符号右移:高位只补0。

2.无符号右移运算练习

例:将一个十进制数转为十六进制数,使用位运算符计算。
方法如下:

 int num = 60;//计算60的十六进制
 int a = num&15;
/*
因为十六进制的一位对应二进制的四位
所以先求十六进制的第一个4位对应值
十六进制中最大的基数为15
因此,&15之后求出结果
*/
 int b = num>>>4;//无符号右移4位,求出十六进制的第二个4位对应值
 System.out.print(b);
 if(a>9){
 System.out.println((char)(a-10+'a'));
 }
/*
十六进制中9以后的数以字母表示
字母‘a’的Unicode编码为97
得到十六进制的第一个4位对应值减去10的差,加上'a'代表的97,得出对应字母的编码值
再转换为Char类型的字母
*/

关于位运算的实际应用,可以参考位运算威力


版权声明:欢迎转载,欢迎扩散,但转载时请标明作者以及原文出处,谢谢合作!             ↓↓↓
上一篇 下一篇

猜你喜欢

热点阅读