Java -- 常见问题

面试题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);
结果输出是?

分析过程:
~按位取反运算符: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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值