题目
选自牛客网
1.下列关于Java中类的构造方法的描述,正确的是()
A.构造方法的返回类型为void
B.可以定义一个类而在代码中不写构造方法。
C.在同一个类中定义的重载构造方法不可以相互调用。
D.子类不允许调用父类的构造方法。
正确答案:B 。
A. 构造方法的返回类型为 void ——
这是错误的。构造方法实际上没有返回类型,它的名称与类名相同,并且不返回任何值。你不能像普通函数那样给构造方法指定返回类型。B. 可以定义一个类而在代码中不写构造方法 —— 这是正确的。如果你没有显式地定义构造方法,Java 编译器会自动为类生成一个默认的无参构造方法。这个默认构造方法没有任何操作。
C. 在同一个类中定义的重载构造方法不可以相互调用 —— 这是错误的。在同一个类中,你可以使用
this
关键字在一个构造方法中调用另一个构造方法,但必须作为第一条语句。D. 子类不允许调用父类的构造方法 —— 这也是错误的。子类可以通过
super
关键字调用父类的构造方法,并且通常需要在子类构造方法的第一条语句中进行调用,如果子类构造方法没有显式调用父类的构造方法,则默认会调用父类的无参数构造方法。
2.执行下面的程序段,语句3的执行次数为(其中n>1)()
for (i = 0; i <= n-1; i++) // (1)
for (j = n; j > i; j–) // (2)
state; // (3)
A.n(n+2)/2
B.(n-1)(n+2)/2
C.n(n+1)/2
D.(n-1)(n+2)
正确答案:C 为了确定语句3的执行次数,我们需要分析这两个嵌套循环的工作原理。
外部循环(第1行)从0到(n-1)迭代,总共迭代(n)次。
内部循环(第2行)对于每次外部循环的迭代,其迭代次数不同。当外部循环变量(i)取不同的值时,内部循环的起始点和终止点也不同。具体来说:
- 当(i=0)时,内部循环从(j=n)迭代到(j=1),共迭代(n)次。
- 当(i=1)时,内部循环从(j=n)迭代到(j=2),共迭代((n-1))次。
- …
- 当(i=n-1)时,内部循环只迭代一次,即(j=n)。
内部循环对于每个(i)值的迭代次数形成一个等差数列:(n, n-1, n-2, …,
1)。我们需要计算这个数列的总和,这将给出语句3的执行次数。
这对应于选项 C (n(n+1)/2)。
java_56">3.java中关于继承的描述正确的是()
A.一个子类只能继承一个父类
B.子类可以继承父类的构造方法
C.继承具有传递性
D.父类一般具有通用性,子类更具体
正确答案:ACD
在Java中关于继承的描述正确的是:A. 一个子类只能继承一个父类 —— 这个说法是正确的。Java 不支持多重继承,这意味着一个类只能继承一个父类。
B. 子类可以继承父类的构造方法 —— 这个说法是不正确的。子类不会直接继承父类的构造方法。子类可以通过
super
关键字来调用父类的构造方法,但这不是继承构造方法的行为。C. 继承具有传递性 —— 这个说法是正确的。如果类 C 继承自类 B,而类 B 继承自类 A,那么类 C 间接地继承了类 A
的特性,这就体现了继承的传递性。D. 父类一般具有通用性,子类更具体 ——
这个说法是正确的。通常情况下,父类提供了一组通用的功能和属性,而子类则扩展或细化这些功能,使之更加具体化。
4.在Java线程状态转换时,下列转换不可能发生的有()?
A.初始态->运行态
B.就绪态->运行态
C.阻塞态->运行态
D.运行态->就绪态
正确答案:AC
在Java中,线程的状态转换遵循一定的规则。线程的生命周期中包含五种状态:初始态、就绪态、运行态、阻塞态、死亡状态。A. 初始态 -> 运行态 —— 这个转换是不可能直接发生的。线程从初始态(即刚刚创建但尚未启动的状态)变为运行态,中间需要经过就绪态。也就是说,当线程被创建并调用
start()
方法后,线程进入就绪态,等待CPU分配时间片开始执行,此时线程才可能进入运行态。B. 就绪态 -> 运行态 —— 这个转换是可能发生的。当线程处于就绪态时,它等待CPU调度,一旦获得CPU时间片,就可以进入运行态。
C. 阻塞态 -> 运行态 —— 这个转换是不可能直接发生的。当线程从阻塞态恢复时,它应该先回到就绪态,然后再由操作系统调度进入运行态。因此,从阻塞态直接跳转到运行态是不符合线程状态转换规则的。
D. 运行态 -> 就绪态 —— 这个转换是可能发生的。当线程正在运行时,如果它的时间片用尽或主动让出CPU(如遇到
yield()
方法),它会从运行态变为就绪态,等待下一次被调度。
5.以下代码执行的结果显示是多少()?
java">public class Demo{public static void main(String[] args){System.out.print(getNumber(0));System.out.print(getNumber(1));System.out.print(getNumber(2));System.out.print(getNumber(4));}public static int getNumber(int num){try{int result = 2 / num;return result;}catch (Exception exception){return 0;}finally{if(num == 0){return -1;}if(num == 1){return 1;}}}
}
A.0110
B.-1110
C.0211
D.-1211
正确答案:B
java">public static int getNumber(int num){try{int result = 2 / num;return result;}catch (Exception exception){return 0;}finally{if(num == 0){return -1;}if(num == 1){return 1;}} }
对于不同的
num
值,我们来分析getNumber
方法的行为:
当
num = 0
时:
- 在
try
块中,尝试执行2 / num
会导致除以零异常,因此会触发catch
块。catch
块返回0
。finally
块中有一个针对num == 0
的条件判断,会覆盖catch
块中的返回值,返回-1
。当
num = 1
时:
- 在
try
块中,2 / num
的结果是2
。return result
返回2
。finally
块中有一个针对num == 1
的条件判断,会覆盖try
块中的返回值,返回1
。当
num = 2
时:
- 在
try
块中,2 / num
的结果是1
。return result
返回1
。finally
块中没有匹配的条件,因此返回值不变,仍然是1
。当
num = 4
时:
- 在
try
块中,2 / num
的结果是0
。return result
返回0
。finally
块中没有匹配的条件,因此返回值不变,仍然是0
。综上所述,当分别调用
getNumber(0)
、getNumber(1)
、getNumber(2)
和getNumber(4)
时,返回值分别为-1
、1
、1
和0
。因此,程序的输出结果是
-1110
。正确答案是 B. -1110。