面试题1:
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是编译失败的呢?为什么呢?
class Demo1 {
public static void main(String[] args) {
byte b1 = 3,b2 = 4,b;
b = b1 + b2;
b = 3 + 4;
System.out.println(b);
}
}
解答:
b = b1 + b2;是有问题的。
因为变量相加,会首先看类型问题,最终把结果赋值的也会考虑类型问题。
常量相加,首先做加法,然后看结果是否在赋值的数据类型范围内,如果不是,才报错。
面试题2:
byte b = 130;有没有问题?如果我想让赋值正确,可以怎么做?结果是多少呢?
class Demo2 {
public static void main(String[] args) {
byte b = 130;
System.out.println(b);
}
}
解答:
有问题。因为byte的范围是:-128到127。而130不在此范围内,所以报错。
如果想让赋值正确可以使用强制类型转换,即byte b = (byte) 130;
最终输出结果为:-126
输出结果分析:
计算机中数据的运算都是补码进行的。
1:获取130这个数据的二进制。
00000000 00000000 00000000 10000010
这个二进制即是130的原码,也是反码,还是补码。2:对以上二进制做截取操作,截成byte类型。
10000010
这个是补码。3:已知补码求原码。
符号位 数值位
补码: 1 0000010
反码: 1 0000001
原码: 1 1111110
输出:- 126输出的是原码
面试题3:
以下输出结果是什么?
1、System.out.println("hello"+'a'+1);
2、System.out.println('a'+1+"hello");
3、System.out.println("5+5="+5+5);
4、System.out.println(5+5+"=5+5");
分析解答:
字符串数据和其他数据做+时,结果是字符串类型,这里的+不是加法运算,而是字符串连接符。
所以输出的结果分别为:
1、helloa1
2、98hello
3、5+5=55
4、10=5+5
面试题4:
int x = 4;
int y = x+++++x+x*10;
请分别计算出x,y的值
分析过程:
y = (x++) + (++x) + (x*10);
先计算x++
起初x的值为4,在做x++操作时,先取x的值作为参与运算的值,即为4;然后x在做++操作,即变成5;此时y = 4 + (++x) + (x*10);
再计算++x
经过上一步的计算,x的值是5,在做++x的操作时,先做++操作,即x的值变成6;然后在将操作后的结果作为参与运算的值,即为6;此时y = 4 + 6 + (x*10);
最后计算x*10
由上一步可以得知,x的值为6;所以此时y = 4 + 6 + (6*10);
综上所述,x,y的值为:x=6;y=70
面试题5:
short s=1;s = s+1;
short s=1;s+=1;
上面两个代码有没有问题,如果有,那里有问题。
解答:
第一个有问题,第二个没有问题
分析过程:
第一个
short类型数据在参与运算时会默认转换成int型数据进行运行,其计算结果为int型,所以当int型数据赋值给short型时需要做强制类型转换,
否则编译会提示“可能损失精度”的错误。
第二个
扩展的赋值运算符其实隐含了一个强制类型转换。
s += 1;
不是等价于 s = s + 1;
而是等价于 s = (s的数据类型)(s + 1);
面试题6
System.out.println(~3);
结果输出是?
分析过程:
~按位取反运算符:0变1,1变0
00000000 00000000 00000000 00000011 (3的补码)
~11111111 11111111 11111111 11111100 (~3的补码)
补码:11111111 11111111 11111111 11111100
反码:11111111 11111111 11111111 11111011
原码:10000000 00000000 00000000 00000100
结果是:-4
故,输出的结果为:-4
需要注意的是,在控制台输出的结果是显示原码,但是在内存中运算过程是用补码的形式计算的。
System.out.println(~-3);
结果输出是?
分析过程:
符号位 数值位
-3的原码: 1 0000000 00000000 00000000 00000011
-3的反码: 1 1111111 11111111 11111111 11111100
-3的补码: 1 1111111 11111111 11111111 11111101
----------------------------------------------------------------
符号位 数值位
-3取反后的补码: 0 0000000 00000000 00000000 00000010
此时符号位为正数,所以-3取反后的反码和原码都相同,为
0000000 00000000 00000000 00000010
故,在控制台输出显示为:2
面试题7:
java中,左移、右移以及无符号右移问题
左移(<<):左边最高位丢弃,右边补0;
左移相当于把数据乘以2的移动次幂。
右移(>>):当最高位是0时,左边补0,右边丢弃;
当最高位是1时,左边补1,右边丢弃;
右移相当于把数据除以2的移动次幂
无符号右移(>>>):无论最高位是0还是1,左边都补0,右边丢弃。
System.out.println(-24>>2);
System.out.println(-24>>>2);
求输出的结果?
分析过程:
位移运算都是以补码的形式进行计算的。
-24>>2 分析过程:
-24的二进制
原码: 10000000 00000000 00000000 00011000
反码: 11111111 11111111 11111111 11100111
补码: 11111111 11111111 11111111 11101000
位移2位(补码位移2位)
补码: 11111111 11111111 11111111 11111010(00)
反码: 11111111 11111111 11111111 11111001
原码: 10000000 00000000 00000000 00000110
所以,System.out.println(-24>>2);输出的结果是:-6
-24>>>2 分析过程:
-24的二进制
原码: 10000000 00000000 00000000 00011000
反码: 11111111 11111111 11111111 11100111
补码: 11111111 11111111 11111111 11101000
位移2位(补码位移2位)
补码: 00111111 11111111 11111111 11111010
反码: 00111111 11111111 11111111 11111010
原码: 00111111 11111111 11111111 11111010
所以,System.out.println(-24>>2);输出的结果是:1073741818