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);结果输出是?分析过程:~按位取反运算符: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
阅读全文
0 0
- java常见问题
- JAVA 常见问题
- Java常见问题
- java常见问题
- Java常见问题
- Java常见问题
- java 常见问题
- Java常见问题
- Java常见问题
- java常见问题
- java常见问题
- JAVA常见问题
- java 常见问题
- java 常见问题
- JAVA常见问题
- Java常见问题
- java常见问题
- java常见问题
- 1479 数据结构实验之栈与队列九:行编辑器
- Linux之redhat初学者基本指令教程(三)——vim教程
- nutch solr系列之(一)win7下安装nutch solr
- Spring框架IOC理解
- 每天一个linux命令(9):touch 命令
- Java -- 常见问题
- 爬虫基础_01——正则
- JSP自定义标签(三)自定义日期选择标签
- 进程和线程的区别和联系
- 最适合做特工的挑战者性格ESTP职业规划要素
- 博客搬家啦!!!
- Hadoop之——Hadoop 2.6.3动态增加/删除DataNode节点
- 解决mnist各种错误,优化提升
- 由C++类指针初始化引起的问题汇总