1. 下面有关java基本类型的默认值和取值范围,说法错误的是?
-
A 字节型的类型默认值是0,取值范围是-2^7—2^7-1
-
B boolean类型默认值是false,取值范围是true\false
-
C 字符型类型默认是0,取值范围是-2^15 —2^15-1
-
D long类型默认是0,取值范围是-2^63—2^63-1
答案:C
题解:注意字符型(char) char 占16位,而且没有负值。所以最小值是0。最大值是2^16 - 1
默认值 取值范围 示例
字节型: 0-2^7 ----- 2^7 - 1 byte b = 10;
字符型: '\u0000'0 ----- 2^16 - 1 char c = 'c';
short: 0-2^15 ----- 2^15 - 1 short s = 10;
int: 0-2^31 ----- 2^31 - 1 int i = 10;
long: 0-2^63 ----- 2^63 - 1 long o = 10L;
float: 0.0f-2^31 ----- 2^31 - 1 float f = 10.0F;
double: 0.0d-2^63 ----- 2^63-1 double d = 10.0;
boolean: false true\false boolean flag = true;
2. 默认RMI采用的是什么通信协议?
-
A HTTP
-
B UDP/IP
-
C TCP/IP
-
D Multicast
答案:C
题解:RMI 全程Remote Method Invocation,意思是远程方法调用,如果只知道Mac地址那就没法玩了,需要直到IP地址,所以采用的是网际层以上的协议,而应用层的协议层次又太高了,比如HTTP。剩下的也就只有TCP/IP协议了。
3. 尝试编译以下程序会产生怎么样的结果?()
1 2 3 4 5 6 7 8 9 |
|
-
A 编译错误将发生在(1),因为构造函数不能指定返回值
-
B 编译错误将发生在(2),因为该类没有默认构造函数
-
C 编译错误将在(3)处发生,因为该类没有构造函数,该构造函数接受一个int类型的参数
-
D 该程序将正确编译和执行
答案:C
题解:这道题要看仔细,MyClass方法并不是参数构造方法,而是返回类型为void的普通方法,普通方法自然需要实例化对象然后去调用它,所以ABD的说法都是错误的,C的说法是正确的,因为没有带参数的构造器,所以自然不能传一个int进去。
4. 下面代码输出是?
1 2 3 |
|
-
A Ceil d1=-0.0 floor d1=-1.0
-
B Ceil d1=0.0 floor d1=-1.0
-
C Ceil d1=-0.0 floor d1=-0.0
-
D Ceil d1=0.0 floor d1=0.0
-
E Ceil d1=0 floor d1=-1
答案:A
题解: 这里主要有一点:
Math.ceil(d1)
ceil方法上有这么一段注释:If the argument value is less than zero but greater than -1.0,then the result is negative zero
如果参数小于0且大于-1,结果为-0
Math.floor(d1)
ceil 和 floor 方法上都有一句话:If the argument is NaN or an infinity or positive zero or negative zero,then the result is the same as the argument,意思为:如果参数是NaN、无穷、正0、负0,那么结果与参数相同,如果是-0.0 , 那么其结果是-0.0
5. 下面哪些类实现或者继承了Collection接口?
-
A HashMap
-
B ArrayList
-
C Vector
-
D Iterator
答案:D
题解:
注意:Iterable 才是Collection 的接口。不是Iterator,Iterator就是一个接口,而且没有继承关系,Iterable和Iterator 没有什么关系
6. Java1.8版本之前的前提,Java特性中,abstract class和interface有什么区别()
-
A 抽象类可以有构造方法,接口中不能有构造方法
-
B 抽象类中可以有普通成员变量,接口中没有普通成员变量
-
C 抽象类中不可以包含静态方法,接口中可以包含静态方法
-
D 一个类可以实现多个接口,但只能继承一个抽象类。
答案:ABD
题解:
在JDK1.8之前的版本(不包括JDK1.8),接口中不能有静态方法,抽象类中因为有普通方法,故也可以有静态方法。
在JDK1.8后(包括JDK1.8),在抽象类中依旧可以有静态方法,同时在接口中也可以定义静态方法了。
以下代码在JDK1.8之后是没有问题的(可以通过接口名来调用静态方法 :Main.prinf(); ):
1 2 3 4 |
|
PS:
在JDK1.7,接口中只包含抽象方法,使用public abstract 修饰。
1 2 3 |
|
在JDK1.8,接口中新加了默认方法和静态方法:
默认方法:使用default修饰,在接口的实现类中,可以直接调用该方法,也可以重写该方法。
静态方法:使用static修饰,通过接口直接调用。
1 2 3 4 5 6 7 8 9 10 11 |
|
在JDK1.9,接口中新加了私有方法,使用private修饰,接口由于不能实例化,静态方法无法调用接口的私有实例方法,这个私有方法只能给默认方法使用。
1 2 3 4 5 |
|
7. 下面哪个语句是创建数组的正确语句?( )
-
A float f[][] = new float[6][6];
-
B float []f[] = new float[6][6];
-
C float f[][] = new float[][6];
-
D float [][]f = new float[6][6];
-
E float [][]f = new float[6][];
答案:ABDE
题解:
数组命名时名称与[]可以随意排列,但声明的二维数组中第一个中括号中必须要有值,它代表的是在该二维数组中有多少个一维数组。 即声明数组时必须明确行数,列数随意。
8. 关于下列程序段的输出结果,说法正确的是:( )
1 2 3 4 5 6 |
|
-
A 有错误,变量i没有初始化。
-
B null
-
C 1
-
D 0
答案:D
题解:成员变量和局部变量的区别
1、成员变量是独立于方法外的变量,局部变量是类的方法中的变量
1)、成员变量:包括实例变量和类变量,用static修饰的是类变量,不用static修饰的是实例变量,所有类的成员变量可以通过this来引用。
2)、局部变量:包括形参,方法局部变量,代码块局部变量,存在于方法的参数列表和方法定义中以及代码块中。
2、成员变量可以被public,protect,private,static等修饰符修饰,而局部变量不能被控制修饰符及 static修饰;两者都可以定义成final型。
3、成员变量存储在堆,局部变量存储在栈。局部变量的作用域仅限于定义它的方法,在该方法的外部无法访问它。成员变量的作用域在整个类内部都是可见的,所有成员方法都可以使用它。如果访问权限允许,还可以在类的外部使用成员变量。
4、局部变量的生存周期与方法的执行期相同。当方法执行到定义局部变量的语句时,局部变量被创建;执行到它所在的作用域的最后一条语句时,局部变量被销毁。类的成员变量,如果是实例成员变量,它和对象的生存期相同。而静态成员变量的生存期是整个程序运行期。
5、成员变量在累加载或实例被创建时,系统自动分配内存空间,并在分配空间后自动为成员变量指定初始化值,初始化值为默认值,基本类型的默认值为0,复合类型的默认值为null。(被final修饰且没有static的必须显式赋值),局部变量在定义后必须经过显式初始化后才能使用,系统不会为局部变量执行初始化。
6、局部变量可以和成员变量 同名,且在使用时,局部变量具有更高的优先级,直接使用同名访问,访问的是局部变量,如需要访问成员变量可以用this.变量名访问
本例中i为成员变量,有默认的初始值,如果定义在方法内部,就没有初始值