- 以下程序输出结果为:(D)
? class Base{
public Base(String s){
System.out.print("B");
}
}
public class Derived extends Base{
public Derived (String s) {
System.out.print("D");
}
public static void main(String[] args){
new Derived("C");
}
}
A BD
B DB
C C
D 编译错误
错选:A
调用子类构造方法必须要先调用父类构造方法。在子类构造里,有默认的super(),且只能在第一行。这会调用父类无参构造,若父类无构造的前提,父类会自动创建出无参构造,但是如果父类有有参构造,则不会自动创建,那super(),就会无用且出错。
?
-
下面关于构造方法的说法不正确的是 (B)
A 构造方法也属于类的方法,可以创建对象的时候给成员变量赋值
B 构造方法不可以重载
C 构造方法没有返回值
D 构造方法一定要和类名相同
错选:A
B:构造方法可以重载。
?
-
下列描述中,错误的是(C)
A SQL语言又称为结构化查询语言
B java中”static”关键字表明一个成员变量或者是成员方法可以在没有所属的类的实例变量的情况下被访问
C 面向对象开发中,引用传递意味着传递的并不是实际的对象,而是对象的引用,因此,外部对引用对象所做的改变不会反映到所引用的对象上
D java是强类型语言,javascript是弱类型语言 E 面向对象的三大特性包括:封装,继承,多态
错选:B
B:被static修饰的是全局可见的。
C:引用传递,除了一些特殊的(String,包装类属于不可变类),一般的引用类型在进行传递的时候,一开始形参和实参都是指向同一个地址的,这个时候形参对对象的改变会影响到实参。
?
-
下列哪种说法是正确的?(C)
A 实例方法可直接调用超类的实例方法
B 实例方法可直接调用超类的类方法
C 实例方法可直接调用本类的类方法
D 实例方法可直接调用其他类的实例方法
错选:D
A、D:静态方法不可以调用成员方法。(静态方法不能调用实例方法)。
B:子类不可以调用父类的私有方法和静态方法。
C:实例方法可以调用本类的实例方法和类方法(即普通方法可以调用静态方法),类方法只能访问类成员变量和调用类方法()。
?
-
程序读入用户输入的一个值,要求创建一个自定义的异常,如果输入值大于 10 ,使用 throw 语句显式地引发异常,异常输出信息为 ”something’swrong!” , 语句为(A)
A if(i>10)throw new Exception("something’swrong!");
B if(i>10)throw Exception e("something’swrong!");
C if(i>10) throw new Exception e("something’swrong!");
D if(i>10)throw Exception( "something’swrong!");
错选:C
throw是语句抛出异常,有两种用法:
抛出异常e实例或新的Exception实例
1.catch中的throw e;
2.方法体中的throw new Exception();
区别如下: throw e是将已经catch到的e重新抛出,而throw new Exception()是重新生成一个Exception类的对象并抛出。有两点重要区别,第一e中记录了原异常的信息,如除零异常的信息,而new Exception()是一个新对象,当中不包含任何有用的信息;第二e可能存在向上转型,即e的实际类型可能是Exception的子类,而new Exception()就是Exception类的对象。
?
-
在创建派生类对象,构造函数的执行顺序(A)
A 基类构造函数,派生类对象成员构造函数,派生类本身的构造函数
B 派生类本身的构造函数,基类构造函数,对象成员构造函数
C 基类构造函数,派生类本身的构造函数,派生类对象成员构造函数
D 对象成员构造函数,基类构造函数,派生类本身的构造函数
错选:C
对象创建时代码的加载顺序为:静态代码 --> 非静态代码 --> 构造方法。
若继承了父类,则加载顺序为:父类的静态的代码 --> 子类的静态的代码 --> 父类内部非静态代码 --> 父类的构造方法 --> 子类的非静态代码 --> 子类的构造方法。
其中,静态代码包括(静态方法,静态变量,静态代码块等),非静态代码即(成员方法,成员变量,成员代码块等),同一种代码,写在上面的先加载。
?