Java位运算符
Java 定义的位运算(bitwise operators )直接对整数类型的位进行操作,这些整数类型包括long,int,short,char,and byte ,用于操作二进制。包括有“&,|,^,~,<<,>>,>>>”
- &:按位与,“只有两个都是1,结果才是1。”
- |:安位或,“只要有一个1,结果就是1。”
- ^:按位异或,“相同的为0,不同的为1。”
- ~:按位取反,“1就是0,0就是1。”
- <<:按位左移,“表示将二进制向左位移,右边填0。”
- >>:按位右移,“表示将二进制向右位移,左边填符号位。”
- >>>:无符号右移动,“表示将二进制向右位移,左边填0。”
分类
按位与运算
按位与运算符"&"是双目运算符。其功能是参与运算的两数 各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1,否则为0。参与运算的数以补码方式出现。例如:9&5可写算式如下: 00001001 (9的二进制补码)&00000101 (5的二进制补码) 00000001 (1的二进制补码)可见9&5=1。
按位与运算通常用来对某些位清0或保留某些位。例如把a 的高八位清 0 , 保留低八位, 可作 a&255 运算 ( 255 的二进制数为0000000011111111)。
main(){
int a=9,b=5,c;
c=a&b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
按位或运算
按位或运算符“|”是双目运算符。其功能是参与运算的两数各 对应的二进位相或。只要对应的二个二进位有一个为1时,结果位就为1。参与运算的两个数均以补码出现。例如:9|5可写算式如下:00001001|00000101 00001101 (十进制为13)可见9|5=13
main(){
int a=9,b=5,c;
c=a|b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
按位异或运算
按位异或运算符“^”是双目运算符。其功能是参与运算的 两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。参与运算数仍以补码出现,例如 9^5可写成算式如下: 00001001^00000101 00001100 (十进制为12)
main(){
int a=9;
a=a^15;
printf("a=%d\n",a);
}
求反运算
求反运算符~为单目运算符,具有右结合性。 其功能是对参 与运算的数的各二进位按位求反。例如~9的运算为: ~(0000000000001001)结果为:1111111111110110
左移运算
左移运算符“<<”是双目运算符。其功能把“<< ”左边的运算数 的各二进位全部左移若干位,由“<<”右边的数指定移动的位数,高位丢弃,低位补0。例如: a<<4 指把a的各二进位向左移动4位。如a=00000011(十进制3),左移4位后为00110000(十进制48)。
右移运算
右移运算符“>>”是双目运算符。其功能是把“>> ”左边的运算数的各二进位全部右移若干位,“>>”右边的数指定移动的位数。例如:设 a=15,a>>2 表示把000001111右移为00000011(十进制3)。应该说明的是,对于有符号数,在右移时,符号位将随同移动。当为正数时, 最高位补0,而为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定。Turbo C和很多系统规定为补1。
总结
(1)移位运算符适用类型有byte、short、char、int、long
(2)对低于int型的操作数将先自动转换为int型再移位。
(3)对于int型整数移位a>>b,系统先将b对32取模,得到的结果才是真正移位的位数。例如:a>>33和a>>1结果是一样的,a>>32的结果还是a原来的数字。
(4)对于long型整数移位时a>>b ,则是先将移位位数b对64取模。移位不会改变变量本身的值。如a>>1;在一行语句中单独存在,毫无意义。
(5)x>>1的结果和x/2的结果是一样的(因此以后要 求解n除以2,可以用n>>1),x<<2和x*4的结果也是一样的。总之,一个数左移n位,就是等于这个数乘以2的n次方,一个数右移n位,就是等于这个数除以2的n次方。