/*【位运算符】
运算符: 运算 范例 说明
<<: 左移 3<<2=12--->3*2*2=12
>>: 右移 3>>2=1---->3/2=1
>>>: 无符号右移 3>>>2=1--->3/2=1
&: 与运算 6 & 3=2
|: 或运算 6 | 3=7
^: 异或运算 6^3=5
~: 反码 ~6=-7
*/
//左移:左移就是乘以2的次幂运算。移几位就是几次幂。
//左移的用处:比如要在计算机中做3*4的运算,
//在计算机中是用二进制相乘的011*100,但是
//现在可以用位运算的方式(左移来运算),
//即把3左移2位就得到结果了,这样的运算速度很快,
//其弊端是只能操作2的倍数,在开发过程中如果要操作2
//的倍数或者2的次幂时,可用位运算来实现。
//右移:右移就是除以2的次幂运算。移几位就是几次幂。
/*
右移时,原最高位是什么,空位就补什么(保持原来的符号性)。
*/
//无符号右移:不用于做除法运算。
/*
无论原最高位是什么,空位都补0.
用处在于:获取二进制中某一段的值 比如:
一个二进制为:00000000 00111100 00000000 00110110
如果三位三位的获取其值(一次右移无符号三位),第一次
右移三位取得的是(110:结果为6),然后去掉这三位,则
下一个三位变成了最低的三位,再获取这个三位……最后得到的
结果是这个二进制对应的八进制数。(获取四位,就是二进制
对应的十六进制)
总结就是:在进行关于2的运算时,考虑左移和右移运算。
在进行二进制的位操作是,要用到无符号右移。
*/
//&运算:
/*
在二进制中在&运算过程中,只有全为1时,结果才为1,
否则为0.
用处是:在获取某一个二进制的某几位的时候比如:
一个二进制为00101011,要获取最后三位是可以用三个1和
最后三个二进制为相与
一句话:用来获取二进制中的有效位1
00101011
00000111
-----------
00000011------最后三位为二进制位
当要获取第二个三位时,可以先把此二进制无符号右移三位
在和00000111相与即可
*/
//|:运算
/*
6|3=
110
|001
----
111 --->7(十进制)
*/
//^:运算
/*
6^3=5
110
^011
----
101 --->5
^011
----
110 --->6
即6^3^3 = 6;
一个数异或另一个数,结果还是原数。(用于加密方面)
*/
//~:取反运算:
/*
~6=-7:计算如下:
6--->00000110 取反得:--->11111001
因为在计算机中是用补码形式存放的。所以要把11111001
看成一段补码,现在把这个补码转换为原码(先变为反码:
减1就行得--->11111000,再变为原码,最高位是符号位,不变
其他为按位取反得--->10000111再转化为十进制为-7)
比如6取反再加1得-6
*/
//位运算符的练习:
/*
1,如何最有效率的计算2*8
通过左移来运算:2<<<3--->2*8 = 16;
//System.out.println(2<<3);--->结果是16
2, 对两个整数变量的值进行互换(不需要第三方变量)
int a = 3,b = 7;
//通过第三方变量的方法如下:
int temp;
temp = a;
a = b;
b = temp;
//(不经过第三方变量)通过和的形式。有个弊端,两个数据较大,可能会超出int范围。
//这个方法不太好
a = a+b; //a = 3+7;
b = a-b; //b = 3+7-7; b = 3;
a = a=b; //a = 3+7-3; a = 7;
//(不经过第三方变量)通过位运算来解决。
a = a^b; //a = 3^7;
b = a^b; //b = 3^7^7; --->b = 3;
a = a^b; //a = 3^7^3; --->a = 7;
*/
//三元运算符:格式:(条件表达式)?表达式1:表达式2;
//int x = 2,y;
//y = x>1?100:200;
//需求:有三个数,想知道最大的是哪个?
/*
int a = 2,b=3,c =4,max;
if(a>b)
max = a;
if(max<b)
max = b;
System.out.println("max="+max);
*/
class OperateDemo1
{
public static void main(String[] args)
{
int a=3,b=40,c=5;
int max;
if(a>b)
max = a;
else
max = b;
if(max<c)
max = c;
else
max = b;
System.out.println("max="+max);
}
}