java深入解析-第2章 运算符与表达式

来源:互联网 发布:flash编程语言 编辑:程序博客网 时间:2024/06/05 18:28

1、编译器在分析字符时,会尽可能多地结合有效字符。并且“过度”地贪心,而不管这种结合方式是否符合语法规则。如i+++j会处理为(i++)+j;然而a–b会处理a– b,编译出错。
2、贪心规则是有用的,因为这样可以对转义字符等进行特殊处理。
3、前置++与后置++都是先将变量的值加1,而不是前置++先加1然后运算,而后置++先运算后加1。
4、从程序上说,后置++先将变量赋值给一个临时变量,然后将变量的值加1,接下来使用那个临时变量参与运算。
5、从指令上说,后置++在执行增值指令钱,先将变量的值压入栈,执行增值指令后,使用的是之前压入栈的值。
6、表 除数为0的浮点运算

被除数除数输出结果值正数(float类型)0(float类型)InfinityFloat.POSITIVE_INFINITY负数(float类型)0(float类型)-InfinityFloat.NEGATIVE_INFINITY0(float类型)0(float类型)NaNFloat.NaN正数(float类型)0(double类型)InfinityDouble.POSITIVE_INFINITY负数(float类型)0(double类型)-InfinityDouble.NEGATIVE_INFINITY0(float类型)0(double类型)NaNDouble.NaN

注意:NaN不等于任何值,因此,不能使用“==”运算符来判断一个值是否是NaN,而是使用Float(Double)类的isNaN方法。
7、表 除法相除运算

被除数\除数有穷正数有穷负数+0-0Infinity-InfinityNaN+0+0-0NaNNaN+0-0NaN-0-0+0NaNNaN-0+0NaNInfinity-InfinityInfinityInfinityNaN+0-0NaN-Infinity-InfinityInfinity-InfinityInfinityNaNNaNNaNNaNNaNNaNNaNNaNNaNNaNNaN

8、在整型中,+0和-0没有任何的区别,但是在浮点类型中,尽管+0与-0在数值上是相等的,使用“==”运算符,结果也为true,不过二者还是有区别的,区别体现在:

  • 当+0与-0参与浮点类型的相关运算时,可以产生不同的结果(符号的差别)。
  • +0与-0在浮点类型变量存储中,符号位是不同的。
  • 某些类会吧浮点类型的+0与-0视为完全不同的两个数值来处理。
0 0
原创粉丝点击