(1) double a = 3.1251111111;
double b = 1.0417037037;
System.out.println((a/3)==b);
System.out.println((b*3)==a);
答案:如果你认真计算,结果应该为true,但实际上不一定为true,我测试的结果为false,这道题不在于你答true或者false,而应该指出这种用法不对。因为计算机采用二进制表示,一个数很可能不能被准确表示。例如0.1表示为二进制0.000110011001100110011,不管采用多长都没有办法表示。所以对它进行加减乘除运算之后的结果也可能是不准确的,所以不能使用等号进行判断。只能按照一定的精度进行处理:
a/3-b>0.0000001 && a/3-b<0.0000001。(这个一定要牢记,在其他语言中也会有这样的问题,至少在C++中有)
(2)
int
a=0123;
int
b=123;
System.
out
.println(a);
System.
out
.println(b);
答案:83 123 (考察8进制和16进制表示)
(3)
int a=9;
int
b=5;
int
c=-5;
System.
out
.println(a/b);//1
System.
out
.println(a/c);//-1
System.
out
.println(a%b);//4
System.
out
.println(a%c);//4
如果把
a=9
改为
a=-9
,结果是什么
答案:1 -1 4 -4 (结果为整数)