首页 > 代码库 > JAVA基础知识——运算符
JAVA基础知识——运算符
1、整数被0除会产生一个异常,而浮点数被0除将会得到无穷大或NaN的结果
2、例如: double w = x * y /z JAVA是注重可移植的语言,但是在进行计算的时候,由于64位存储一个double值和80位浮点寄存器存储一个double值是不一样的,很多Intel处理器都是一步一计算的(这样计算的结果更精确),最后结果再截断为64位,这就和64位的机器计算的结果有所不同(直接结算,没有中间过程),一次运算一储存,有可能出现溢出或者计算速度慢的情况,JAVA程序设计语言承认了最优性能和理想结果之间存在的冲突,并做了改进。在默认的情况下,虚拟机设计者允许将中间计算结果采用扩展的精度,但是对于使用strictfp关键字标记的方法必须使用严格的浮点计算来产生理想的结果。例如:public static strictfp void main(String[] args),于是main方法中的所有浮点计算都要进行严格的计算。
3、自增运算符、自减运算符
前缀方式先+1再运算,后缀方式则是先运算后+1
4、关系运算符和boolean运算符
&&表示逻辑“与”、||表示逻辑“或”、!表示逻辑“非” 它们采用“短路”的方式进行运算(也就是说 一旦第一个操作数能够确定表达式的值,第二个就没有必要计算了)
三元操作符:a?b:c
5、位运算符:&(“与”)、|(“或”)、^(“异或”)、~(“非”)
位运算符主要针对二进制
在处理整型数值时,可以直接对组成整数数值的各个位进行操作,这就意味着可以使用屏蔽技术获得整数中的各个位
&和|运算符应用于布尔值,得到的结果也是布尔值,运算方式和&&、||不一样,它们不按短路方式计算,而是一定要计算两个操作的数的值
(1)&(“与”): 两个操作数都为1,结果才是1,否则就是0
例如:int a = 129;
int b = 128;
System.out.println("输出结果是"+(a&b)); //结果为128, “a”的值是129,转换成二进制就是10000001,而“b”的值是128,转换成二进制就是10000000。所以知道结果就是10000000,即128。
(2)|(“或”): 两个操作数只要有一个为1,结果就是1,否则为0
例如:int a=129;
int b=128;
System.out.println("输出结果是"+(a|b)); //结果为129
(3)^(“异或”): 两个操作数中两个相同为0,不同为1
例如:int a = 15;
int b = 2 ;
System.out.println(“输出的结果是”+(a^b)); //结果为13 “a”的值是15,转换成二进制为1111,而“b”的值是2,转换成二进制为0010,所以可以得出其结果为1101 即13。
(4)~(非运算符) 如果位为1,则结果为0,如果位为0,则结果为1
例如: int a = 2;
System.out.println("a 非的结果是:"+(~a));
6、移位运算符:”<<“ 左移 、 “>>” 右移 ”>>>“ 无符号右移
(位运算符的计算比算数计算中的乘除运算速率更快)
左移n位相当于*2的n次幂(低位用0补),右移n位相当于/2的n次幂(如果值为正,则在高位补0,如果值为负,则在高位补1.),无符号右移,忽略符号位,所有空位都以0补齐
7、数学函数与常量:
Math方法(静态方法)的头文件为:import static java.lang.Math.*;
Math类提供的常用的三角函数:Math.sin Math.cos Math.tan Math.atan Math.atan2
Math类提供的指数函数以及它的反函数——自然对数以及以10为底的对数:Math.exp Math.log Math.log10
JAVA中没有幂运算,需要借助Math类中的pow方法。例如:double y = Math.pow(x,a);
JAVA还提供了两个用于表示π(pai)和e常量的近似值:Math.PI Math.E
8、数值类型之间的转换:
低精度——>高精度 无信息丢失
高精度——>高精度 有可能有信息丢失
强制类型转换的方法:Math.round(遵循四舍五入)
9、枚举类型:
enum Size{SMALL, MEDIUM,LARGE,EXTRA_LARGE};
Size s = Size.MEDIUM;
Size类型的变量只能存储这个类型声明中给定的某个枚举值,或者null值,null表示这个变量没有设置任何的值
JAVA基础知识——运算符