-
下面描述函数重写错误的是
A. 要有子类继承或实现
B. 子类方法的权限必须大于等于父类的权限
C.父类中被private权限修饰的方法可以被子类重写
D.子类重写接口中的抽象方法,子类的方法权限必须是public的 //接口所有方法前面都是默认public abstract -
下面关于类的设计思路描述错误的是 ( )
A. 根据需求定义类所包含的字段(成员变量)
B. 根据面向对象的思想要求,隐藏属性和实现细节之后,可以提供公共的访问方式
C.封装之后的字段在本类内也必须使用get/set方法 //private修饰之后可以在本类中直接使用,不需要通过get/set方法调用
D. 按需求可以在类中定义若干构造方法 -
分析如下Java代码,如果想在控制台上输出“B类的test()方法”,则在主函数应填入( )。
class A {
public void test() {
System.out.println(“A类的test()方法”);
}
}
class B extends A {
public void test() {
System.out.println(“B类的test()方法”);
}
public static void main(String args[]) {}
}
A. A a = new B();
a.test();
B. A a = new A();
a.test();
C. B b = new A();
b.test();
D. new B().test(); -
关于封装下面介绍错误的是( )。
A. 封装隐藏实现细节
B. 封装提高重用性。
C.封装提高安全性
D. 只有被private修饰才叫做封装 //仅仅是封装的一种 -
试图编译运行下面的代码会发生什么情况
public class MyClass{
static int i; // int型的成员变量默认值为 0
public static void main(String[] args){
System.out.println(i);
}
}
A. 错误,变量i没有被初始化
B. 输出null
C.输出1
D.输出0 -
下面对static的描述正确的是
A. 静态修饰的成员变量和成员方法随着类的加载而加载
B. 静态修饰的成员方法可以访问非静态成员变量 //对象都没有,访问什么呀?
C. 静态修饰的成员可以被整个类对象所共享
D.静态修饰的成员变量和成员方法随着类的消失而消失 -
给定java代码,如下:
abstract class Shape {
abstract void draw( );
}
要创建Shape类的子类Circle,以下代码正确的是()。
A. class Circle extends Shape{ int draw( ){} }
B. abstract class Circle extends Shape{ }
C.class Circle extends Shape{ void draw( ); }
D.class Circle extends Shape{ void draw( ){ } } -
在Java中,下面对于构造函数的描述正确的是( )。
A. 类必须显式定义构造函数
B. 构造函数的返回类型是void // 构造器(函数)没有返回值类型,什么都不用写.
C.构造函数和类有相同的名称,并且不能带任何参数
D.一个类可以定义多个构造函数 -
下面Java代码的运行结果是( )。
class Penguin {
//下面蓝色的部分被称为 属性 , 字段 , 成员变量
private String name=null; // 名字
private int health=0; // 健康值
private String sex=null; // 性别
public void Penguin() { // 构造方法没有void,所以这是个普通的方法
health = 10;
sex = “雄”;
System.out.println(“执行构造方法。”);
}
public void print() {
System.out.println(“企鹅的名字是” + name +
“,健康值是” + health + “,性别是” + sex+ “。”);
}
public static void main(String[] args) {
Penguin pgn = new Penguin();
pgn.print();
}
}
A. 企鹅的名字是null,健康值是10,性别是雄。
B. 执行构造方法。
企鹅的名字是null,健康值是0,性别是null。
C.企鹅的名字是null,健康值是0,性别是null。
D.执行构造方法。
企鹅的名字是null,健康值是10,性别是雄。 -
在Java中,下面关于抽象类的描述正确的是()。
A. 抽象类本身可以被实例化
B. 如果一个类中有一个方法被声明为抽象的,那么这个类必须是抽象类
C.抽象类中的方法必须都是抽象的
D.声明抽象类必须带有关键字abstract -
给定如下Java程序代码,在_____横线处加入( )语句,可以使这段代码编译通过。
interface Parent{
public int count(int i);
}
public class Test implements Parent {
public int count(int i){
return i % 9;
}
}
public static void main(String[] args){
________________
int i = p.count(20);
}
}
A. Test p = new Test();
B. Parent p;
C.Parent p = new Parent();
D.Test p = new Parent(); -
下面说法正确的是( )。
A. 匿名内部类编译后不会生成.class文件 //也会生成 , 大家可以自己试下.
B. 接口编译后不会生成.class文件 //也会有的 , 大家可以自己试下.
C.抽象类中没有构造方法 //有构造方法, 给子类使用.
D.局部内部类只能访问被final修饰的局部变量。 -
类Student中构造方法声明正确的是哪一项? ()
A:class Student
{
public Student()
}
B:class Student
{
public Student(){}
}
C:class Student
{
public void Student(){}
}
D:class Student
{
new Student(){}
} -
下面对this的作用描述错误的是
A. 当成员变量和局部变量重名的时候可以用this区分
B. this()语句必须放在构造函数的第一行,根据this后面括号中的参数调用本类其他的构造函数.
C.this可以用本类的一般函数
D.this可以调用父类的一般函数 //需要首先调用父类的属性或方法,要用super关键字 -
在Java中,以下程序编译运行后的输出结果为( )。
public class Test {
int x, y;
Test(int x, int y) {
this.x = x;
this.y = y;
}
public static void main(String[] args) {
Test pt1, pt2;
pt1 = new Test(3, 3);
pt2 = new Test(4, 4);
System.out.print(pt1.x + pt2.x);
}
}
A. 6
B. 3 4
C.8
D.7 -
在java中,已定义了两个接口B和C,以下语句正确的是 ( )
A. interface A extends B,C
B. interface A implements B,C
C.class A implements B,C
D.class A implements B,implements C -
给定一个Java程序Test.java的代码如下所示,编译时,会出现以下( )情况。
class Parent {
public int count() { // 第1行
return 0;
}
}
public class Test extends Parent {
public float count() { // 第2行 //子类重写父类方法,要求返回值必须一致.按继承算也会报错,因为构不成重载
return 9; // 第3行
}
}
A. 编译通过
B. 在第1行引发编译错误
C.在第2行引发编译错误
D.在第3行引发编译错误 -
在Java接口中定义常量,下面语法正确的是( )。
A. static final int MALE = 1;
B. final int MALE = 1;
C.int MALE = 1;
D.private int MALE = 1;
public static final int MALE = 1; 接口中只定义常量的方法.
public abstract 返回值 method(); 接口中只定义抽象方法. -
给定Java程序Child.java的代码如下所示,则编译运行该类的结果是( )。
class Parent {
Parent() {
System.out.println(“parent”);
}
}
public class Child extends Parent {
Child(String s) {
System.out.println(s);
}
public static void main(String[] args) {
Child child = new Child(“child”); //先调用父类的无参构造函数,再调自己的有参构造.
}
}
A. child
B. child
parent
C.parent
child
D.编译错误 -
下列选项中关于Java中super关键字的说法错误的是( )。
A. 当子父类中成员变量重名的时候,在子类方法中想输出父类成员变量的值,可以用super区分子父类成员变量
B. super语句可以放在构造函数的任意一行 //super()语句必须放在第1行,死规定,记住.
C.子类可以通过super关键字调用父类的方法
D.子类可以通过super关键字调用父类的属性 -
分析如下所示的Java代码,则选项中的说法正确的是( )。
class Parent{
public String name;
public Parent(String pName){
this.name = pName;
}
}
public class Test extends Parent { //1
public Test(String Name){ //2
name=“hello”; //3
super(“kitty”); //4 //super()语句必须放在第1行,死规定,记住.
}
}
A. 第2行错误,Test类的构造函数中参数名称应与其父类构造函数中的参数名相同
B. 第3行错误,应使用super关键字调用父类的name属性,改为super.name=“hello”;
C.第4行错误,调用父类构造方法的语句必须放在子类构造方法中的第一行
D.程序编译通过,无错误 -
以下关于Object类说法错误的是( )。
A. 一切类都直接或间接继承自Object类
B. 接口也继承Object类 // 接口并没有继承Object类. 所有的接口都默认具备Object中的方法的抽象形式 , 以备给子类使用 .
C.Object类中定义了toString()方法
D.Object类在java.lang包中 -
在Java中,多态的实现不仅能减少编码的工作量,还能大大提高程序的可维护性及可扩展性,下面哪一个选项不属于多态的条件( )。
A. 子类重写父类的方法
B. 子类重载同一个方法 //重载是指同一个类中重名方法,但是参数不同(参数个数,参数顺序,参数类型不同)
C.要有继承或实现
D.父类引用指向子类对象 -
编译运行如下Java代码,输出结果是( )。
class Base {
public void method(){
System.out.print (“Base method”);
}
}
class Child extends Base{
public void methodB(){
System.out.print (“Child methodB”);
}
}
class Sample {
public static void main(String[] args) {
Base base = new Child();
base.methodB(); // 父类中没有methodB()方法,所以会报错.
}
}
A. Base method
B. Child methodB
C.Base method Child MethodB
D.编译错误 -
下面关于Java接口的说法正确的是( )。
A. Java接口中定义的是扩展功能
B. Java接口中可以被多个子类实现,一个类也可以同时实现多个接口
C.Java接口中可以声明私有成员
D.Java接口本身不能被实例化
26.在Java接口中,下列选项中属于有效的方法声明是( )。
A. public void aMethod();//接口中默认Public abstract 方法 方法名();
B. final void aMethod();//这也是不行的,final修饰后就不能被子类实现
C.void aMethod(){}
D.private void aMethod();
-
下面说法中错误的是
A. 静态代码块只在类加载的时候执行一次 , 以后再创建对象的时候不执行
B. 局部代码块的作用是为了限制变量的生命周期
C.构造代码块在每创建一次对象就执行一次
D.以上都不对 -
在Java中,如果父类中的某些方法不包含任何逻辑,并且需要有子类重写,应该使用( )关键字来声明父类的这些方法。
A. final
B. static
C.abstract
D.void -
给定两个java程序,如下:
public interface Face{
int counter = 40;
}
public class Test implements Face{
private static int counter; // 默认值为 0
public static void main(String[]args){
System.out.println(++counter);
}
}
Test.java 的编译运行结果是( )。
A. 40
B. 41
C.0
D.1 -
Java中,如果类C是类B的子类,类B是类A的子类,那么下面描述正确的是( )。
A. C可以继承B中的公有成员,同样也可以继承A中的公有成员
B. C只继承了B中的成员
C.C只继承了A中的成员
D.C不能继承A或B中的成员 -
给定java程序,如下:
public class Test{
private static final int counter=10; //常量不能被改变默认大写 COUNTER
public static void main(String [] args){
System.out.println(++counter);
}
}
编译运行Test.java,结果是 ( )
A. 10
B. 11
C.编译错误
D.运行时出现异常 -
下面关于变量及其范围的陈述哪些是对的? ( )
A. 实例变量(区别于类变量,属于对象的变量)是类的成员变量。
B. 实例变量用关键字static声明。
C. 在方法中定义的局部变量在该方法被执行时创建
D. 局部变量在使用前必须被初始化。 -
给定一个Java程序代码,如下:
public class Test{
int count = 9;
public void count1(){
int count =10;
System.out.println(“count1=”+count); // 10
}
public void count2(){
System.out.println(“count2=”+count); // 9
}
public static void main(String args[]){
Test t=new Test();
t.count1();
t.count2();
}
}
编译运行后,输出结果是
A. count1=9 count2=9
B. count1=10 count2=9
C.count1=10 count2=10
D.count1=9 count2=10
-
关于构造方法和set方法,关于这两个方法描述错误的是( )
A. 构造方法是用来为对象的成员变量进行初始化赋值的
B. set方法是为对象中成员变量赋值的
C.带参构造在创建对象的时候也可以为成员变量赋值
D.类中的带参构造方法与set方法功能是完全重复的,可以只选其一 //构造方法只能在创建对象的时候为成员变量赋值;set方法功能是在对象创建之后对成员变量的值进行修改。set方法在对象的整个生命周期都可以对成员变量的值进行修改,相对灵活。 -
程序Test.java编译运行后输出的结果是( )。
public class Test {
String s1=“java”;
public static void main(String args[]) {
int z=2;
Test t=new Test();
System.out.println(t.s1+z);
}
}
A. java2
B. 2
C.没有输出结果
D.java -
下面关于外部类和内部类成员的相互访问的规则中,正确的选项是( )。
A. 内部类可以直接访问外部类的成员
B. 外部类可以直接访问内部类的成员
C. 外部类不能访问内部类的成员
D. 外部类可通过创建内部类的实例来访问内部类的成员 -
用于定义类成员的访问控制权的一组关键字是( )。
A. class, float, double, public
B. float, boolean, int, long
C. char, extends, float, double
D. public, private, protected -
给定java代码,如下:编译运行,结果是
public static void main (String [] args){
String s;
System.out.println(“s=”+s); //s没有赋值.所以编译出错.
}
A. 编译错误
B. 编译通过,但出现运行时错误
C.正常运行,输出s=null
D.正常运行,输出s= -
关于类和对象的叙述正确的是:( )
A.Java的类分为两大部分:系统定义的类和用户自定义的类
B.类的静态成员变量(类变量)和普通成员变量(实例变量)的概念完全一样,只是表达形式不同 //static
C.定义一个类时,该类的成员至少要有一个成员变量和一个成员方法 //可以空类
D.类是对象的实例化 -
构造函数何时被调用? ( )
A. 创建对象时
B. 类定义时
C. 使用对象的方法时
D. 出现super()时