java,每日练习02

题目

选自牛客网

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)。

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.以下代码执行的结果显示是多少()?

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

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 方法的行为:

  1. num = 0 时:

    • try 块中,尝试执行 2 / num 会导致除以零异常,因此会触发 catch 块。
    • catch 块返回 0
    • finally 块中有一个针对 num == 0 的条件判断,会覆盖 catch 块中的返回值,返回 -1
  2. num = 1 时:

    • try 块中,2 / num 的结果是 2
    • return result 返回 2
    • finally 块中有一个针对 num == 1 的条件判断,会覆盖 try 块中的返回值,返回 1
  3. num = 2 时:

    • try 块中,2 / num 的结果是 1
    • return result 返回 1
    • finally 块中没有匹配的条件,因此返回值不变,仍然是 1
  4. num = 4 时:

    • try 块中,2 / num 的结果是 0
    • return result 返回 0
    • finally 块中没有匹配的条件,因此返回值不变,仍然是 0

综上所述,当分别调用 getNumber(0)getNumber(1)getNumber(2)getNumber(4) 时,返回值分别为 -1110

因此,程序的输出结果是 -1110

正确答案是 B. -1110

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

布说在见

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值