Java -- 常见问题

来源:互联网 发布:大学生网络受骗原因 编辑:程序博客网 时间:2024/06/05 07:03

面试题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、helloa12、98hello3、5+5=554、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);结果输出是?分析过程:~按位取反运算符:0110        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