JavaSE-易错题集-002

1. 下面有关java基本类型的默认值和取值范围,说法错误的是?

  • A 字节型的类型默认值是0,取值范围是-2^7—2^7-1
  • B boolean类型默认值是false,取值范围是true\false
  • C 字符型类型默认是0,取值范围是-2^15 —2^15-1
  • D long类型默认是0,取值范围是-2^63—2^63-1

答案:C

题解:注意字符型(char) char 占16位,而且没有负值。所以最小值是0。最大值是2^16 - 1

 默认值                 取值范围                               示例

字节型:         0-2^7 ----- 2^7 - 1                  byte b = 10;

字符型:       '\u0000'0 ----- 2^16 - 1             char c = 'c';

short:           0-2^15 ----- 2^15 - 1               short s = 10;

int:               0-2^31 ----- 2^31 - 1               int i = 10;

long:            0-2^63 ----- 2^63 - 1               long o = 10L;

float:            0.0f-2^31 ----- 2^31 - 1           float f = 10.0F;

double:        0.0d-2^63 ----- 2^63-1            double d = 10.0;

boolean:      false true\false                        boolean flag = true;


2. 默认RMI采用的是什么通信协议?

  • A HTTP
  • B UDP/IP
  • C TCP/IP
  • D Multicast

答案:C

题解:RMI 全程Remote Method Invocation,意思是远程方法调用,如果只知道Mac地址那就没法玩了,需要直到IP地址,所以采用的是网际层以上的协议,而应用层的协议层次又太高了,比如HTTP。剩下的也就只有TCP/IP协议了。


3. 尝试编译以下程序会产生怎么样的结果?()

1

2

3

4

5

6

7

8

9

public class MyClass {

    long var;

    public void MyClass(long param) { var = param; }//(1)

    public static void main(String[] args) {

        MyClass a, b;

        a =new MyClass();//(2)

        b =new MyClass(5);//(3)

    }

}

  • A 编译错误将发生在(1),因为构造函数不能指定返回值
  • B 编译错误将发生在(2),因为该类没有默认构造函数
  • C 编译错误将在(3)处发生,因为该类没有构造函数,该构造函数接受一个int类型的参数
  • D 该程序将正确编译和执行

 答案:C

题解:这道题要看仔细,MyClass方法并不是参数构造方法,而是返回类型为void的普通方法,普通方法自然需要实例化对象然后去调用它,所以ABD的说法都是错误的,C的说法是正确的,因为没有带参数的构造器,所以自然不能传一个int进去。


4. 下面代码输出是?

1

2

3

double d1=-0.5;

System.out.println("Ceil d1="+Math.ceil(d1));

System.out.println("floor d1="+Math.floor(d1));

  • A Ceil d1=-0.0
      floor d1=-1.0
  • B Ceil d1=0.0
      floor d1=-1.0
  • C Ceil d1=-0.0
      floor d1=-0.0
  • D Ceil d1=0.0
      floor d1=0.0
  • E Ceil d1=0
      floor d1=-1

答案:A

题解: 这里主要有一点:

Math.ceil(d1)

ceil方法上有这么一段注释:If the argument value is less than zero but greater than -1.0,then the result is negative zero

如果参数小于0且大于-1,结果为-0

Math.floor(d1)

ceil 和 floor 方法上都有一句话:If the argument is NaN or an infinity or positive zero or negative zero,then the result is the same as the argument,意思为:如果参数是NaN、无穷、正0、负0,那么结果与参数相同,如果是-0.0 , 那么其结果是-0.0


5. 下面哪些类实现或者继承了Collection接口?

  • A HashMap
  • B ArrayList
  • C Vector
  • D Iterator

答案:D

题解:

 

 注意:Iterable 才是Collection 的接口。不是Iterator,Iterator就是一个接口,而且没有继承关系,Iterable和Iterator 没有什么关系


6. Java1.8版本之前的前提,Java特性中,abstract class和interface有什么区别()

  • A 抽象类可以有构造方法,接口中不能有构造方法
  • B 抽象类中可以有普通成员变量,接口中没有普通成员变量
  • C 抽象类中不可以包含静态方法,接口中可以包含静态方法
  • D 一个类可以实现多个接口,但只能继承一个抽象类。

答案:ABD

题解:

在JDK1.8之前的版本(不包括JDK1.8),接口中不能有静态方法,抽象类中因为有普通方法,故也可以有静态方法。

在JDK1.8后(包括JDK1.8),在抽象类中依旧可以有静态方法,同时在接口中也可以定义静态方法了。

以下代码在JDK1.8之后是没有问题的(可以通过接口名来调用静态方法  :Main.prinf(); ):

1

2

3

4

public interface Demo{

    public static void print() {         

      System.out.println("Hello World!");      }

}

PS:

在JDK1.7,接口中只包含抽象方法,使用public abstract  修饰。

1

2

3

public interface Demo{

    public abstract void method();

}

在JDK1.8,接口中新加了默认方法和静态方法:

        默认方法:使用default修饰,在接口的实现类中,可以直接调用该方法,也可以重写该方法。

        静态方法:使用static修饰,通过接口直接调用。

1

2

3

4

5

6

7

8

9

10

11

public interface Demo{

    //默认方法

    public default void method(){

        System.out.println("default method...");

    }

    //静态方法

    public static void print(){

        System.out.println("static method...");

    }

}

在JDK1.9,接口中新加了私有方法,使用private修饰,接口由于不能实例化,静态方法无法调用接口的私有实例方法,这个私有方法只能给默认方法使用。

1

2

3

4

5

public interface Demo{

    private void method() {

        System.out.println("Hello World!");

    }

}


7. 下面哪个语句是创建数组的正确语句?( )

  • A float f[][] = new float[6][6];
  • B float []f[] = new float[6][6];
  • C float f[][] = new float[][6];
  • D float [][]f = new float[6][6];
  • E float [][]f = new float[6][];

答案:ABDE

题解:

数组命名时名称与[]可以随意排列,但声明的二维数组中第一个中括号中必须要有值,它代表的是在该二维数组中有多少个一维数组。 即声明数组时必须明确行数,列数随意。


8. 关于下列程序段的输出结果,说法正确的是:( )

1

2

3

4

5

6

public class MyClass{

    static int i;

    public static void main(String argv[]){

        System.out.println(i);

    }

}

  • A 有错误,变量i没有初始化。
  • B null
  • C 1
  • D 0

答案:D

题解:成员变量和局部变量的区别

1、成员变量是独立于方法外的变量,局部变量是类的方法中的变量

    1)、成员变量:包括实例变量类变量,用static修饰的是类变量,不用static修饰的是实例变量,所有类的成员变量可以通过this来引用。
    2)、局部变量:包括形参,方法局部变量,代码块局部变量,存在于方法的参数列表和方法定义中以及代码块中。
2、成员变量可以被public,protect,private,static等修饰符修饰,而局部变量不能被控制修饰符及 static修饰;两者都可以定义成final型。
3、成员变量存储在堆,局部变量存储在栈。局部变量的作用域仅限于定义它的方法,在该方法的外部无法访问它。成员变量的作用域在整个类内部都是可见的,所有成员方法都可以使用它。如果访问权限允许,还可以在类的外部使用成员变量。
4、局部变量的生存周期与方法的执行期相同。当方法执行到定义局部变量的语句时,局部变量被创建;执行到它所在的作用域的最后一条语句时,局部变量被销毁。类的成员变量,如果是实例成员变量,它和对象的生存期相同。而静态成员变量的生存期是整个程序运行期。
5、成员变量在累加载或实例被创建时,系统自动分配内存空间,并在分配空间后自动为成员变量指定初始化值,初始化值为默认值,基本类型的默认值为0,复合类型的默认值为null。(被final修饰且没有static的必须显式赋值),局部变量在定义后必须经过显式初始化后才能使用,系统不会为局部变量执行初始化。

6、局部变量可以和成员变量 同名,且在使用时,局部变量具有更高的优先级,直接使用同名访问,访问的是局部变量,如需要访问成员变量可以用this.变量名访问

本例中i为成员变量,有默认的初始值,如果定义在方法内部,就没有初始值

 

  • 12
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值