- 浏览: 67567 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
fabulasia:
试过了,没卵用
android程序在LogCat没有日志输出解决方案 -
心惶惶呀:
有用
android程序在LogCat没有日志输出解决方案 -
jialeadmin:
写的不错 很基础
JAVA面试题解惑系列(十)——话说多线程 -
skying007:
哥们,你写的太经典了。受益匪浅!!!!
JAVA面试题解惑系列(十一)——这些运算符你是否还记得? -
skying007:
总结的真不错,辛苦了。
125常见JAVA技术面试题
原文地址:http://rmyd.group.iteye.com/group/topic/6193
基本类型,或者叫做内置类型,是JAVA中不同于类的特殊类型。它们是我们编程中使用最频繁的类型,因此面试题中也总少不了它们的身影,在这篇文章中我们
将从面试中常考的几个方面来回顾一下与基本类型相关的知识。
基本类型共有八种,它们分别都有相对应的包装类。关于它们的详细信息请看
下表:
基本类型可以分为三类,字符类型char,布尔类型boolean以及数值类型byte、short、int、long、float、double。数值 类型又可以分为整数类型byte、short、int、long和浮点数类型float、double。JAVA中的数值类型不存在无符号的,它们的取值 范围是固定的,不会随着机器硬件环境或者操作系统的改变而改变。实际上,JAVA中还存在另外一种基本类型void,它也有对应的包装类 java.lang.Void,不过我们无法直接对它们进行操作。对于数值类型的基本类型的取值范围,我们无需强制去记忆,因为它们的值都已经以常量的形 式定义在对应的包装类中了。请看下面的例子:
public class PrimitiveTypeTest { public static void main(String[] args) { // byte System.out.println("基本类型:byte 二进制位数:" + Byte.SIZE); System.out.println("包装类:java.lang.Byte"); System.out.println("最小值:Byte.MIN_VALUE=" + Byte.MIN_VALUE); System.out.println("最大值:Byte.MAX_VALUE=" + Byte.MAX_VALUE); System.out.println(); // short System.out.println("基本类型:short 二进制位数:" + Short.SIZE); System.out.println("包装类:java.lang.Short"); System.out.println("最小值:Short.MIN_VALUE=" + Short.MIN_VALUE); System.out.println("最大值:Short.MAX_VALUE=" + Short.MAX_VALUE); System.out.println(); // int System.out.println("基本类型:int 二进制位数:" + Integer.SIZE); System.out.println("包装类:java.lang.Integer"); System.out.println("最小值:Integer.MIN_VALUE=" + Integer.MIN_VALUE); System.out.println("最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE); System.out.println(); // long System.out.println("基本类型:long 二进制位数:" + Long.SIZE); System.out.println("包装类:java.lang.Long"); System.out.println("最小值:Long.MIN_VALUE=" + Long.MIN_VALUE); System.out.println("最大值:Long.MAX_VALUE=" + Long.MAX_VALUE); System.out.println(); // float System.out.println("基本类型:float 二进制位数:" + Float.SIZE); System.out.println("包装类:java.lang.Float"); System.out.println("最小值:Float.MIN_VALUE=" + Float.MIN_VALUE); System.out.println("最大值:Float.MAX_VALUE=" + Float.MAX_VALUE); System.out.println(); // double System.out.println("基本类型:double 二进制位数:" + Double.SIZE); System.out.println("包装类:java.lang.Double"); System.out.println("最小值:Double.MIN_VALUE=" + Double.MIN_VALUE); System.out.println("最大值:Double.MAX_VALUE=" + Double.MAX_VALUE); System.out.println(); // char System.out.println("基本类型:char 二进制位数:" + Character.SIZE); System.out.println("包装类:java.lang.Character"); // 以数值形式而不是字符形式将Character.MIN_VALUE输出到控制台 System.out.println("最小值:Character.MIN_VALUE=" + (int) Character.MIN_VALUE); // 以数值形式而不是字符形式将Character.MAX_VALUE输出到控制台 System.out.println("最大值:Character.MAX_VALUE=" + (int) Character.MAX_VALUE); } }
运行结果:
1、基本类型:byte 二进制位数:8
2、包装类:java.lang.Byte
3、最小
值:Byte.MIN_VALUE=-128
4、最大值:Byte.MAX_VALUE=127
5、
6、基本类
型:short 二进制位数:16
7、包装类:java.lang.Short
8、最小
值:Short.MIN_VALUE=-32768
9、最大值:Short.MAX_VALUE=32767
10、
11、
基本类型:int 二进制位数:32
12、包装类:java.lang.Integer
13、最小
值:Integer.MIN_VALUE=-2147483648
14、最大
值:Integer.MAX_VALUE=2147483647
15、
16、基本类型:long 二进制位数:64
17、
包装类:java.lang.Long
18、最小值:Long.MIN_VALUE=-9223372036854775808
19、
最大值:Long.MAX_VALUE=9223372036854775807
20、
21、基本类型:float
二进制位数:32
22、包装类:java.lang.Float
23、最小值:Float.MIN_VALUE=1.4E-
45
24、最大值:Float.MAX_VALUE=3.4028235E38
25、
26、基本类型:double
二进制位数:64
27、包装类:java.lang.Double
28、最小值:Double.MIN_VALUE=4.9E-
324
29、最大值:Double.MAX_VALUE=1.7976931348623157E308
30、
31、基
本类型:char 二进制位数:16
32、包装类:java.lang.Character
33、最小
值:Character.MIN_VALUE=0
34、最大值:Character.MAX_VALUE=65535
Float
和Double的最小值和最大值都是以科学记数法的形式输出的,结尾的“E+数字”表示E之前的数字要乘以10的多少倍。比如3.14E3就是
3.14×1000=3140,3.14E-3就是3.14/1000=0.00314。
大家将运行结果与上表信息仔细比较就会发现
float、double两种类型的最小值与Float.MIN_VALUE、Double.MIN_VALUE的值并不相同,这是为什么呢?实际上
Float.MIN_VALUE和Double.MIN_VALUE分别指的是float和double类型所能表示的最小正数。也就是说存在这样一种情
况,0到±Float.MIN_VALUE之间的值float类型无法表示,0到±Double.MIN_VALUE之间的值double类型无法表示。
这并没有什么好奇怪的,因为这些范围内的数值超出了它们的精度范围。
基本类型存储在栈中,因此它们的存取速度要快于存储在堆中的对应
包装类的实例对象。从Java5.0(1.5)开始,JAVA虚拟机(Java Virtual
Machine)可以完成基本类型和它们对应包装类之间的自动转换。因此我们在赋值、参数传递以及数学运算的时候像使用基本类型一样使用它们的包装类,但
这并不意味着你可以通过基本类型调用它们的包装类才具有的方法。另外,所有基本类型(包括void)的包装类都使用了final修饰,因此我们无法继承它
们扩展新的类,也无法重写它们的任何方法。
各种数值类型之间的赋值与转换遵循什么规律呢?我们来看下面这个例子:
public class PrimitiveTypeTest { public static void main(String[] args) { // 给byte类型变量赋值时,数字后无需后缀标识 byte byte_a = 1; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // byte byte_b = 1000; // 把一个long型值赋值给byte型变量,编译时会报错,即使这个值没有超出byte类型的取值范围 // byte byte_c = 1L; // 给short类型变量赋值时,数字后无需后缀标识 short short_a = 1; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // short short_b = 70000; // 把一个long型值赋值给short型变量,编译时会报错,即使这个值没有超出short类型的取值范围 // byte short_c = 1L; // 给short类型变量赋值时,数字后无需后缀标识 int int_a = 1; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // int int_b = 2200000000; // 把一个long型值赋值给int型变量,编译时会报错,即使这个值没有超出int类型的取值范围 // int int_c = 1L; // 可以把一个int型值直接赋值给long型变量,数字后无需后缀标识 long long_a = 1; // 如果给long型变量赋予的值超出了int型值的范围,数字后必须加L(不区分大小写)标识 long long_b = 2200000000L; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // long long_c = 9300000000000000000L; // 可以把一个int型值直接赋值给float型变量 float float_a = 1; // 可以把一个long型值直接赋值给float型变量 float float_b = 1L; // 没有F(不区分大小写)后缀标识的浮点数默认为double型的,不能将它直接赋值给float型变量 // float float_c = 1.0; // float型数值需要有一个F(不区分大小写)后缀标识 float float_d = 1.0F; // 把一个double型值赋值给float型变量,编译时会报错,即使这个值没有超出float类型的取值范围 // float float_e = 1.0D; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // float float_f = 3.5000000E38F; // 可以把一个int型值直接赋值给double型变量 double double_a = 1; // 可以把一个long型值直接赋值给double型变量 double double_b = 1L; // 可以把一个float型值直接赋值给double型变量 double double_c = 1F; // 不带后缀标识的浮点数默认为double类型的,可以直接赋值 double double_d = 1.0; // 也可以给数字增加一个D(不区分大小写)后缀标识,明确标出它是double类型的 double double_e = 1.0D; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // double double_f = 1.8000000000000000E308D; // 把一个double型值赋值给一个byte类型变量,编译时会报错,即使这个值没有超出byte类型的取值范围 // byte byte_d = 1.0D; // 把一个double型值赋值给一个short类型变量,编译时会报错,即使这个值没有超出short类型的取值范围 // short short_d = 1.0D; // 把一个double型值赋值给一个int类型变量,编译时会报错,即使这个值没有超出int类型的取值范围 // int int_d = 1.0D; // 把一个double型值赋值给一个long类型变量,编译时会报错,即使这个值没有超出long类型的取值范围 // long long_d = 1.0D; // 可以用字符初始化一个char型变量 char char_a = 'a'; // 也可以用一个int型数值初始化char型变量 char char_b = 1; // 把一个long型值赋值给一个char类型变量,编译时会报错,即使这个值没有超出char类型的取值范围 // char char_c = 1L; // 把一个float型值赋值给一个char类型变量,编译时会报错,即使这个值没有超出char类型的取值范围 // char char_d = 1.0F; // 把一个double型值赋值给一个char类型变量,编译时会报错,即使这个值没有超出char类型的取值范围 // char char_e = 1.0D; // 编译器会做范围检查,如果赋予的值超出了范围就会报错 // char char_f = 70000; } }
从上面的例子中我们可以得出如下几条结论:
1、未带有字符后缀标识的整数默认为int类型;未带有字符后缀标识的浮点数默认为
double类型。
2、如果一个整数的值超出了int类型能够表示的范围,则必须增加后缀“L”(不区分大小写,建议用大写,因为小写的L与
阿拉伯数字1很容易混淆),表示为long型。
3、带有“F”(不区分大小写)后缀的整数和浮点数都是float类型的;带有“D”(不区分
大小写)后缀的整数和浮点数都是double类型的。
4、编译器会在编译期对byte、short、int、long、float、
double、char型变量的值进行检查,如果超出了它们的取值范围就会报错。
5、int型值可以赋给所有数值类型的变量;long型值可
以赋给long、float、double类型的变量;float型值可以赋给float、double类型的变量;double型值只能赋给
double类型变量。
下图显示了几种基本类型之间的默认逻辑转换关系:
图中的实线表示无精度损失的转换,而虚线则表示这样的转换可能会损失一定的精度。如果我们想把一个能表示更大范围或者更高精度的类型,转换为一个范围更小 或者精度更低的类型时,就需要使用强制类型转换(Cast)了。不过我们要尽量避免这种用法,因为它常常引发错误。请看下面的例子,如果不运行代码,你能 预测它的结果吗?
public class PrimitiveTypeTest { public static void main(String[] args) { int a = 123456; short b = (short) a; // b的值会是什么呢? System.out.println(b); } }
运行结果:
1、-7616
运算符对基本类型的影响
当使用+、-、*、/、%运算符对基本类型进行运算时,遵循如下规则:
1、只要两个操作数中有一个是double类型的,另一个将会
被转换成double类型,并且结果也是double类型;
2、否则,只要两个操作数中有一个是float类型的,另一个将会被转换成
float类型,并且结果也是float类型;
3、否则,只要两个操作数中有一个是long类型的,另一个将会被转换成long类型,并且结
果也是long类型;
4、否则,两个操作数(包括byte、short、int、char)都将会被转换成int类型,并且结果也是int类
型。
当使用+=、-=、*=、/=、%=、运算符对基本类型进行运算时,遵循如下规则:
1、运算符右边的数值将
首先被强制转换成与运算符左边数值相同的类型,然后再执行运算,且运算结果与运算符右边数值类型相同。
了解了这些,我们就能解答下面
这个常考的面试题了。请看:
short s1=1;s1=s1+1;有什么错?short s1=1;s1+=1;有什么错?
乍一看,觉得它们都应该没有错误,可以正常运行。我们来写个例子试试:
public class PrimitiveTypeTest { public static void main(String[] args) { short s1 = 1; // 这一行代码会报编译错误 // s1 = s1 + 1; // 这一行代码没有报错 s1 = 1 + 1; // 这一行代码也没有报错 s1 += 1; } }
从例子中我们可以看出结果了。利用上面列举的规律,也很容易解释。在s1=s1+1;中,s1+1运算的结果是int型,把它赋值给一个short型变量 s1,所以会报错;而在s1+=1;中,由于是s1是short类型的,所以1首先被强制转换为short型,然后再参与运算,并且结果也是short类 型的,因此不会报错。那么,s1=1+1;为什么不报错呢?这是因为1+1是个编译时可以确定的常量,“+”运算在编译时就被执行了,而不是在程序执行的 时候,这个语句的效果等同于s1=2,所以不会报错。前面讲过了,对基本类型执行强制类型转换可能得出错误的结果,因此在使用+=、-=、*=、 /=、%=等运算符时,要多加注意。
Math.round()方法
java.lang.Math类里有两个round()方法,它们的定义如下:
public static int round(float a) { //other code } public static long round(double a) { //other code }
它们的返回值都是整数,且都采用四舍五入法。运算规则如下:
1、如果参数为正数,且小数点后第一位>=5,运算结果为参数的整
数部分+1。
2、如果参数为负数,且小数点后第一位>5,运算结果为参数的整数部分-1。
3、如果参数为正数,且小数点后
第一位<5;或者参数为负数,且小数点后第一位<=5,运算结果为参数的整数部分。
我们可以通过下面的例子来验证:
public class MathTest { public static void main(String[] args) { System.out.println("小数点后第一位=5"); System.out.println("正数:Math.round(11.5)=" + Math.round(11.5)); System.out.println("负数:Math.round(-11.5)=" + Math.round(-11.5)); System.out.println(); System.out.println("小数点后第一位<5"); System.out.println("正数:Math.round(11.46)=" + Math.round(11.46)); System.out.println("负数:Math.round(-11.46)=" + Math.round(-11.46)); System.out.println(); System.out.println("小数点后第一位>5"); System.out.println("正数:Math.round(11.68)=" + Math.round(11.68)); System.out.println("负数:Math.round(-11.68)=" + Math.round(-11.68)); } }
运行结果:
1、小数点后第一位=5
2、正数:Math.round(11.5)=12
3、负
数:Math.round(-11.5)=-11
4、
5、小数点后第一位<5
6、正
数:Math.round(11.46)=11
7、负数:Math.round(-11.46)=-11
8、
9、小数点
后第一位>5
10、正数:Math.round(11.68)=12
11、负
数:Math.round(-11.68)=-12
根据上面例子的运行结果,我们还可以按照如下方式总结,或许更加容易记忆:
1、
参数的小数点后第一位<5,运算结果为参数整数部分。
2、参数的小数点后第一位>5,运算结果为参数整数部分绝对值+1,符号
(即正负)不变。
3、参数的小数点后第一位=5,正数运算结果为整数部分+1,负数运算结果为整数部分。
switch语句
哪些类型可以用于switch语句的判断呢?我们做个测试就知道了:
public class MathTest { // 枚举类型,Java5.0以上版本可用 static enum enum_e { A, B } public static void main(String[] args) { // byte byte byte_n = 0; switch (byte_n) { case 0: System.out.println("byte可以用于switch语句"); break; } // Byte类 Byte byte_m = 0; // 需要Java5.0(1.5)以上版本支持 switch (byte_m) { case 0: System.out.println("Byte类可以用于switch语句"); System.out.println(); break; } // char char char_n = 0; switch (char_n) { case 0: System.out.println("char可以用于switch语句"); break; } // Character类 Character char_m = 0; // 需要Java5.0(1.5)以上版本支持 switch (char_m) { case 0: System.out.println("Character类可以用于switch语句"); System.out.println(); break; } // short short short_n = 0; switch (short_n) { case 0: System.out.println("short可以用于switch语句"); break; } // Short Short short_m = 0; // 需要Java5.0(1.5)以上版本支持 switch (short_m) { case 0: System.out.println("Short类可以用于switch语句"); System.out.println(); break; } // int int int_n = 0; switch (int_n) { case 0: System.out.println("int可以用于switch语句"); break; } // Integer类 Integer int_m = 0; // 需要Java5.0(1.5)以上版本支持 switch (int_m) { case 0: System.out.println("Integer类可以用于switch语句"); System.out.println(); break; } // long long long_n = 0; // 编译错误,long型不能用于switch语句 // switch (long_n) { // case 0: // System.out.println("long可以用于switch语句"); // break; // } // Long类 Long long_m = 0L; // 编译错误,Long类型不能用于switch语句 // switch (long_m) { // case 0: // System.out.println("Long类可以用于switch语句"); // System.out.println(); // break; // } // float float float_n = 0.0F; // 编译错误,float型不能用于switch语句 // switch (float_n) { // case 0.0F: // System.out.println("float可以用于switch语句"); // break; // } // Float类 Float float_m = 0.0F; // 编译错误,Float类型不能用于switch语句 // switch (float_m) { // case 0.0F: // System.out.println("Float类可以用于switch语句"); // System.out.println(); // break; // } // double double double_n = 0.0; // 编译错误,double型不能用于switch语句 // switch (double_n) { // case 0.0: // System.out.println("double可以用于switch语句"); // break; // } // Double类 Double double_m = 0.0; // 编译错误,Double类型不能用于switch语句 // switch (double_m) { // case 0.0: // System.out.println("Double类可以用于switch语句"); // System.out.println(); // break; // } // boolean boolean bool_b = true; // 编译错误,boolean型不能用于switch语句 // switch (bool_b) { // case true: // System.out.println("boolean可以用于switch语句"); // break; // } // Boolean类 Boolean bool_l = true; // 编译错误,Boolean类型不能用于switch语句 // switch (bool_l) { // case true: // System.out.println("Boolean类可以用于switch语句"); // System.out.println(); // break; // } // String对象 String string_s = "Z"; // 编译错误,long型不能用于switch语句 // switch (string_s) { // case "Z": // System.out.println("String可以用于switch语句"); // System.out.println(); // break; // } // enum(枚举类型,Java5.0以上版本可用) switch (MathTest.enum_e.A) { case A: System.out.println("enum可以用于switch语句-A"); break; case B: System.out.println("enum可以用于switch语句-B"); break; } } }
运行结果如下:
1、byte可以用于switch语句
2、Byte类可以用于switch语句
3、
4、
char可以用于switch语句
5、Character类可以用于switch语句
6、
7、short可以用于
switch语句
8、Short类可以用于switch语句
9、
10、int可以用于switch语句
11、
Integer类可以用于switch语句
12、
13、enum可以用于switch语句-A
结果已经出来了,
我们来总结一下:
1、byte、char、short、int四种基本类型以及它们的包装类(需要Java5.0/1.5以上版本支
持)都可以用于switch语句。
2、long、float、double、boolean四种基本类型以及它们的包装类(在Java所有版
本中)都不能用于switch语句。
3、enum类型,即枚举类型可以用于switch语句,但是要在Java5.0(1.5)版本以上才支
持。
4、所有类型的对象(包括String类,但在Java5.0/1.5以上版本中,该项要排除byte、char、short、int四
种基本类型对应的包装类)都不能用于switch语句。
发表评论
-
JAVA面试题解惑系列(十一)——这些运算符你是否还记得?
2010-11-09 13:48 1134原文地址:http://rmyd.grou ... -
JAVA面试题解惑系列(十)——话说多线程
2010-11-09 13:43 1217原文地址:http://rmyd.grou ... -
JAVA面试题解惑系列(九)——继承、多态、重载和重写
2010-11-09 13:34 990原文地址:http://rmyd.grou ... -
JAVA面试题解惑系列(七)——日期和时间的处理
2010-11-09 11:14 1434原文地址:http://rmyd.group.iteye.co ... -
JAVA面试题解惑系列(六)——字符串(String)杂谈
2010-11-09 11:06 778原文地址:http://rmyd.group.iteye.co ... -
JAVA面试题解惑系列(五)——传了值还是传了引用?
2010-11-09 10:46 787原文地址:http://rmyd.group.iteye.co ... -
JAVA面试题解惑系列(四)——final、finally和 finalize的区别
2010-11-09 10:26 768原文地址:http://rmyd.grou ... -
JAVA面试题解惑系列(三)——变量(属性)的覆盖
2010-11-09 10:22 770原帖地址:http://zangweiren.iteye.co ... -
JAVA面试题解惑系列(二)——到底创建了几个String对象?
2010-11-09 09:25 707原文地址:http://zangweiren.iteye.co ... -
JAVA面试题解惑系列(一)——类的初始化顺序
2010-11-09 09:19 561原文地址:http://zangweiren.iteye.co ...
相关推荐
.46 1.8 JAVA面试题解惑系列(八)——聊聊基本类型(内置类型) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .63 1.9 JAVA面试题解惑系列(九)——继承、多态、重载和重写 . . . . . . . . . . ....
Java面试题解惑系列主要涵盖了Java编程语言的核心概念、进阶技术以及在面试中常见的问题。这个压缩包可能包含了两本书籍,一本是"JAVA面试题解惑系列.pdf",另一本是"臧圩人--JAVA面试题解惑系列合集.pdf"。这些资源...
《经典JAVA面试题解惑系列合集(臧圩人)》这本书很可能就是针对这些问题进行深入解析的一本指南。 首先,Java的基础知识是面试中的必考部分。这包括但不限于Java语法、数据类型、控制结构(如if语句、for循环、...
来自网络,主要包括以下内容:1、类初始化的顺序;2、到底创建了几个String对象;3、变量(属性)的覆盖...8.基本类型总结;9.继承,多态,重载,重写;10.多线程;11.运算符总结。 适合将要笔试面试Java的朋友参考。
在Java中,类的初始化顺序是一个经常被问及的面试题目,尤其对于Java程序员和工程师来说,了解这个知识点是必须的。在Java中,类的初始化顺序是面试中的经典问题之一,它涉及到继承、静态成员以及实例成员等多个方面...
JAVA面试题解惑系列 大家在去参加面试的时候,经常会遇到这样的考题:给你两个类的代码,它们之间是继承的 关系,每个类里只有构造器方法和一些变量,构造器里可能还有一段代码对变量值进行了某 种运算,另外还有...
Java全能学习面试手册——互联网企业面试真题.zip 01 java面试——北京-百度-Java中级.pdf 02 java面试——北京-京东-Java中级.pdf 03 java面试——广州-唯品会-Java大数据开发工程师.pdf 04 java面试——杭州-阿里...
Java面试题是每个Java开发者在求职过程中必须面对的挑战,涵盖范围广泛,从基础概念到高级特性和设计模式。这份终极列表包含115个Java面试题和答案,旨在帮助求职者全面准备,以期在面试中表现出色。以下是部分核心...
“JAVA面试题解惑系列(八)——聊聊基本类型(内置类型)”涵盖了Java的原始数据类型,包括int、char、boolean等,它们与引用类型的不同之处以及它们的默认值和范围。 “JAVA面试题解惑系列(九)——继承、多态、...
【标题】"JAVA面试题解惑系列.zip" 提供的内容主要聚焦于Java编程语言在面试中的常见问题及其解答。这通常涉及到Java的核心概念、高级特性、设计模式、并发编程、集合框架、IO/NIO流、异常处理、垃圾回收机制、多...
### Java程序员面试题详解 #### 一、Java基础知识 1. **作用域public, private, protected, 以及不写时的区别** - **public**: 可以被任何类访问。 - **protected**: 可以被同一包内及不同包内的子类访问。 - ...
面试题包含了不同技术层面的面试问题,同时也能对一些没有面试开发经验的小白给予不可估量的包装, 让你的薪水绝对翻倍, 本人亲试有效.Java面试题84集、java面试专属及面试必问课程,所有的面试题有视屏讲解, 解答方案....