书接上文
9.运算符与优先级
位运算符:
对两个操作数中的每一个二进制位都进行运算。与逻辑门相同。
~ | 按位取反 |
& | 按位与 |
| | 按位或 |
^ | 按位异或 |
位移运算符:
左移:"a<<b;"将二进制形式的a逐位左移b位,最低位空出的b补0
带符号右移:"a>>b;"将二进制形式的a逐位右移b位,最高为空出的b位补原来的符号位
无符号右移:"a>>>b;"将二进制形式的a逐位右移b位,最高为空出的b位补0
例子:
面试题:以最快速度计算8*4结果
8:00000000 00000000 00000000 00001000
32:00000000 00000000 00000000 00100000
使用位移的方法是最快的:int result = 8 << 2;
System.out.print(8 << 2);
使用某个数乘2的n次方时,最快的计算方法是:System.out.print(x << n);除的时候,写成这样:System.out.print(x >> n);
---------------------------------------------------------------------------------------------------------------------------
例:通过键盘输入,初始化这两个数将这两个数据交换位置后再输出。
import java.util.Scanner;
public class d
{
public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
System.out.print("请输入一个数字:");
double a = input.nextDouble();
System.out.print("请再输入一个数字:");
double b = input.nextDouble();
//1、使用第三个变量(不解释)
double c = a;
a = b;
b = c;
//2、不用第三个变量
//2、1:通过表达式(括号里是一个整体,式子从左往右算,a+b是他们的和,b=a此时b已经为a了,和-a为b,外面的a此时变为b)
a = a + b - ( b = a );
//2、2:通过+、-运算(a+b是他们的和,此时啊为和,a-b(第二行)算出来是a的之,啊还是和,第三行a-b,此时b为a,第三行的a就是b了)
a = a + b;
b = a - b;
a = a - b;
//2、3:异或方式(相同为假不同为真。这里面后面运算结果若是真,前面的变量等于后面两个变量的后面那个,是假就是前面那个)这个a和b不能相同,另外我用double类型的不行,不知道用int行不行
a = a ^ b;
b = a ^ b;
a = a ^ b;
//乘除方式(不演示)
//上面的5中方法,把其中4个注释掉即可
System.out.print("两数交换后为:a = " + a + ",b = " + b);
}
}