21、Which of the following assignment is not correct?
: C3 W4 w+ X% ^; c) x( j; ]$ uA. float f = 11.1;
0 t2 X# a! d2 j y" Z6 FB. double d = 5.3E12; 2 m+ y0 R( ^8 L4 w6 |8 M
C. double d = 3.14159;
6 ?0 E: I' o, L% ^& \D. double d = 3.14D. 2 w7 W5 @0 ]4 F, C4 C& e# x
(a) 8 S! v5 b* E8 ?. j
题目:下面的哪些赋值语句是不对的。
: o( S7 G, R% s浮点数的赋值是带有小数点的数字缺省是double型的,如果在浮点数后面加f或者F则是float,后面加d或者D则是double,科学计数法形式的浮点数也是double型的,而double的精度比float高,将一个高精度的double赋值给一个低精度的float时需要进行强制类型转换,反之则不需要。 : n# N0 }) W% n! Y& G# G
22、Given the uncompleted code of a class: & G& u& D8 [, G
class Person { ! ?) @' X' \7 n* K5 P4 U* \
String name, department;
. p. q( l$ d8 M X4 `int age; ( {2 G+ F9 ~' {
public Person(String n){ name = n; }
/ {2 j x# u8 X& D- y# y- Mpublic Person(String n, int a){ name = n; age = a; } 2 ?8 |9 r. Q9 m' v+ G
public Person(String n, String d, int a) { , x- l# `. M) w0 @* Q9 P
// doing the same as two arguments version of constructor
% J. B. {6 u9 p6 b6 k// including assignment name=n,age=a
& Z# M$ r% _% r/ Idepartment = d; / `6 _6 L: x/ `- Q/ }
} 3 c+ z0 M& U. O, O* e
}
' m5 d0 ?) ?5 Z" d. v0 z; ZWhich expression can be added at the "doing the same as..." part of the constructor?
" n# {+ i9 @. p9 D8 }2 ^* GA. Person(n,a); 5 J, z2 A" ~$ K8 K
B. this(Person(n,a));
, U' |2 ?) E( pC. this(n,a);
8 @+ q# v6 X% G4 d4 A/ ZD. this(name,age).
- \- I$ \. D+ d* c2 f0 A(c) 4 e! }% g y/ ^, q! L2 p
题目:给出下面的不完整的类代码:
; j# G# s# N& Z, u7 P5 H6 v… ' l1 ?0 Y z5 }
下面的哪些表达式可以加到构造方法中的"doing the same as..."处?
6 Q: _2 }2 |- g. f3 B" c在同一个类的不同构造方法中调用该类的其它构造方法需要使用this(…)的形式,而且必须是在构造方法的第一行调用,这个和普通的方法重载调用的方式不同,普通的方法可以直接使用方法名加参数来调用,而且调用位置没有限制,因此答案A是不行的,B的语法就是错误的,D的错误在于在父类型的构造函数被调用前不能引用类的成员。构造方法是一个类对象实例化的起点(虽然严格来说首先执行的并不是构造方法的第一个语句,而是内存的分配),因此在构造方法中不能将成员作为参数引用。 23、Which of the following statements about variables and their scopes are true?
( H! k+ @6 [7 c$ v3 ]/ B7 p/ `A. Instance variables are member variables of a class. * w2 Q) h! b9 s/ t0 d
B. Instance variables are declared with the static keyword. 0 _6 w. R. \1 z8 c5 |1 X
C. Local variables defined inside a method are created when the method is executed.
/ W* h/ c. A; }1 T$ p2 W2 OD. Local variables must be initialized before they are used. # Q3 Q4 e4 G5 C: B7 l" G3 r
(acd)
a$ R; |6 g5 }! I题目:下面关于变量及其范围的陈述哪些是对的。
* D$ T# a+ L8 X+ Z6 b aA. 实例变量是类的成员变量。
% F* ~( q! W2 oB. 实例变量用关键字static声明。 0 _( y: T/ Q* f2 [& T
C. 在方法中定义的局部变量在该方法被执行时创建
3 x6 `! B# s1 m- uD. 局部变量在使用前必须被初始化。 6 S2 r/ j4 [" k4 B
类中有几种变量,分别是:局部变量(英文可以为:local\automatic\temporary\stack variable)是定义在方法里的变量;实例变量(英文为:instance variable)是在方法外而在类声明内定义的变量,有时也叫成员变量;类变量(英文为:class variable)是用关键字static声明的实例变量,他们的生存期分别是:局部变量在定义该变量的方法被调用时被创建,而在该方法退出后被撤销;实例变量在使用new Xxxx()创建该类的实例时被创建,而其生存期和该类的实例对象的生存期相同;类变量在该类被加载时被创建,不一定要用new Xxxx()创建,所有该类的实例对象共享该类变量,其生存期是类的生存期。任何变量在使用前都必须初始化,但是需要指出的是局部变量必须显式初始化,而实例变量不必,原始类型的实例变量在该类的构造方法被调用时为它分配的缺省的值,整型是0,布尔型是false,而浮点型是0.0f,引用类型(类类型)的实例变量的缺省值是null(没有进行实际的初始化,对它的使用将引起NullPointException),类变量的规则和实例变量一样,不同的是类变量的初始化是在类被加载时。
5 y: Z$ G* C: r7 @2 A+ N24、public void test() {
3 ~/ i. k' f5 T/ Q7 H& O. d Etry { oneMethod();
& K2 h% F6 ~* Y% _% c- F4 g2 uSystem.out.println("condition 1"); , h% ?5 a2 v! ?* o2 d* S
} catch (ArrayIndexOutOfBoundsException e) { . y+ R9 Q1 t: \1 ?9 U, [% F8 l
System.out.println("condition 2");
7 P) `3 `! c9 y7 H5 O} catch(Exception e) {
. i2 T# y' x7 d. y; V, L8 nSystem.out.println("condition 3"); - z7 _2 Q: c) x( [
} finally {
: S4 q0 c, z, e( A6 @: r7 F; WSystem.out.println("finally"); ) _4 G) R# |- z, R8 A+ O3 I) m/ c
}
. }, N4 q1 ?9 M- {}
' J2 }3 g) f: C* p3 `' U+ M5 bWhich will display if oneMethod run normally? 5 O B: ^2 B" i. {' U4 h
A. condition 1 . e1 \: w2 a7 i$ Q) s
B. condition 2
) l* m P) D# U' a$ k" @C. condition 3
7 v1 s: l9 r/ Y" E4 eD. finally
( x9 s9 x3 o, L* H% A2 x) \(ad)
" T4 D9 [2 E- e& G, ]; B* c. [% i7 i题目:在oneMethod()方法运行正常的情况下将显示什么?
/ q6 \; Y3 M2 f! k$ B; n5 z6 F1 \如果try块中的语句在执行时发生异常,则执行从该处中断而进入catch块,根据异常的类型进行匹配,最前面的优先进行匹配比较,只要该异常是catch中指定的异常的子类就匹配成功进而执行相应的catch中的内容,而finally块中的内容无论是否发生异常都将被执行。 # [6 W! k0 _9 a" L4 S
9 i7 G- w x' H25、Given the following code:
' T% J5 s! P* I3 `( D, {% F, wpublic class Test {
( g7 J% C8 r) Lvoid printValue(int m){ 3 b: n N* |) B: }% _
do { System.out.println("The value is"+m); k0 E$ E, A7 K. P2 ^8 M: v! t- S) u
}
7 l. @. q" U% o& f1 Z1 \5 K2 M% k8 Fwhile( --m > 10 ) $ x! G W* j9 I( P: C" W7 |
} 9 Y8 ~+ B0 o8 ~3 p
public static void main(String arg[]) {
. ~& }4 f; N2 \0 u1 {int i=10;
9 _- p& n2 ?& G0 r( u; O8 c6 V; }Test t= new Test(); - M* p3 a! h; }4 T/ N
t.printValue(i);
2 j. S2 |: R" k- G; |8 H( T; N, Q}
~2 R; s. P5 u( F$ j} " A- w# I2 b' N1 v
Which will be output?
9 E/ m' `5 p7 q3 sA. The value is 8 . x$ @3 R* O+ ]4 W' b0 m3 P( B
B. The value is 9
# D( X/ j b; Q% M! j) fC. The value is 10
- f" _1 M- A9 C. bD. The value is 11 ) T# Y c' R' B+ X; F
(c)
/ O) P* } C& ^题目:给出下面的代码:
2 ?% j0 T( O: A* Q W4 ~+ A…
3 v% y- l K, S* r3 H+ |输出将是什么?
$ h5 ]% _8 H) }: D0 i此题考察的是do… while循环和 -- 操作符的知识,do…while最少被执行一次,在执行完do中的内容后判断while中的条件是否为true,如果为true的话就再执行do中的内容,然后再进行判断,以此类推直到while的判断为false时退出循环执行循环后面的内容,而?操作符的规则是在变量右边的 -- 将先进行运算,然后才是使变量的值减一,而在变量左边的是先将变量的值减一再运算。 - k/ {* E2 k- z# u/ l
26、Which of the following statements about declaration are true?
( a0 j/ I; k; w7 u1 o GA. Declaration of primitive types such as boolean, byte and so on does not allocate memory space for the variable.
5 c! ~7 J% a9 @) B/ [" L# RB. Declaration of primitive types such as boolean, byte and so on allocates memory space for the variable. ' b2 J6 a5 D' F' [
C. Declaration of nonprimitive types such as String, Vector and so on does not allocate memory space for the object.
: {# M1 G, J/ q* A# [D. Declaration of nonprimitive types such as String, Vector ans so on allocates memory space for the object.
9 O8 I6 E# U3 O2 ] U(ad) 8 f3 |- N5 {) Z! \
题目:下面的有关声明的哪些叙述是对的。
( Z% B% |" H) W: u7 t% e( hA. 对原始数据类型例如boolean,byte的变量的声明不会为该变量分配内存空间。 0 `* {4 D; D( o, i
B. 对原始数据类型例如boolean,byte的变量的声明将为之分配内存空间。
4 f4 r+ H7 K! j# O" ?C. 非原始数据类型例如String,Vector的变量的声明不会为该对象分配内存。
! u% m. w" N4 l- f& ]D. 非原始数据类型例如String,Vector的变量的声明会为该对象分配内存。 3 j" Q o" N, s; }
对原始数据类型的变量的声明将为之分配内存并赋予一个缺省值,参见23题的叙述,而非原始数据类型的变量必须用new Xxxx()分配内存及初始化。但是严格来讲此题的答案有待确定,因为只有原始类型的实例变量和类变量的声明在类对象被创建/类被加载时完成内存的自动分配,而原始类型的局部变量必须显式初始化,从这点来看原始类型的局部变量没有被自动分配内存,SL275中只提出了非原始数据类型的变量必须使用new Xxxx()完成内存的分配而没有指出原始数据类型的变量是否在声明时即自动进行内存分配,而从局部变量不能在显式初始化前使用这点来看在声明时没有进行内存分配。因此答案a的正确性还有待官方的确定。 |