• 日常Java练习题


    1、下面所示的java代码,运行时,会产生()类型的异常
    int Arry_a[] = new int[10];
    System.out.println(Arry_a[10]);
    正确答案: D 你的答案: D (正确)
    ArithmeticException
    NullPointException
    IOException
    ArrayIndexOutOfBoundsException

    题解:
    定义的数组长度为10,角标即为0-9 访问数组角标10会出现数组角标越界异常 ArithmeticException 算术异常 NullPointException 空指针异常 IOException IO异常 ArrayIndexOutOfBoundsException 数组下标越界异常

    2、关于依赖注入,下列选项中说法错误的是()
    正确答案: B 你的答案: B (正确)
    依赖注入能够独立开发各组件,然后根据组件间关系进行组装
    依赖注入使组件之间相互依赖,相互制约
    依赖注入提供使用接口编程
    依赖注入指对象在使用时动态注入

    题解:
    依赖注入的动机就是减少组件之间的耦合度,使开发更为简洁

    3、子类A继承父类B, A a = new A(); 则父类B构造函数、父类B静态代码块、父类B非静态代码块、子类A构造函数、子类A静态代码块、子类A非静态代码块 执行的先后顺序是?
    正确答案: C 你的答案: C (正确)
    父类B静态代码块->父类B构造函数->子类A静态代码块->父类B非静态代码块->子类A构造函数->子类A非静态代码块
    父类B静态代码块->父类B构造函数->父类B非静态代码块->子类A静态代码块->子类A构造函数->子类A非静态代码块
    父类B静态代码块->子类A静态代码块->父类B非静态代码块->父类B构造函数->子类A非静态代码块->子类A构造函数
    父类B构造函数->父类B静态代码块->父类B非静态代码块->子类A静态代码块->子类A构造函数->子类A非静态代码块

    题解:
    会先执行静态代码块,因为静态代码块是类级别的,是在创建对象之前就执行的。因为子类继承了父类,所以父类的静态代码块会先执行,接着执行子类的静态代码块。
    因为构造函数可能要给动态代码块的一些成员变量赋值,所以必须在这之前先执行动态代码块,要不然构造函数会出现相关的成员属性无定义。所以会先执行动态代码块,在执行构造函数。一般先按父类的执行,再按子类的执行。

    4、以下代码在编译和运行过程中会出现什么情况

    public class TestDemo{
        private int count;
        public static void main(String[] args) {
            TestDemo test=new TestDemo(88);
            System.out.println(test.count);
        }
         TestDemo(int a) {
             count=a;
        }
    }

    编译运行通过,输出结果是88
    编译时错误,count变量定义的是私有变量
    编译时错误,System.out.println方法被调用时test没有被初始化
    编译和执行时没有输出结果

    题解:
    private是私有变量,只能用于当前类中,题目中的main方法也位于当前类,所以可以正确输出

    5、Web程序中,当前用户上下文信息应该保存在下面哪个对象中()
    正确答案: C 你的答案: C (正确)
    page
    request
    session
    Application

    题解:
    当前用户上下文信息:session
    appication:当前应用
    pageContext:当前页面
    request:当前请求

    6、下面哪个不属于HttpServletResponse接口完成的功能?
    正确答案: C 你的答案: C(正确)
    设置HTTP头标
    设置cookie
    读取路径信息
    输出返回数据

    题解:
    request读取路径信息

    7、以下说法错误的是()
    正确答案: D 你的答案: D(正确)
    虚拟机中没有泛型,只有普通类和普通方法
    所有泛型类的类型参数在编译时都会被擦除
    创建泛型对象时请指明类型,让编译器尽早的做参数检查
    泛型的类型擦除机制意味着不能在运行时动态获取List中T的实际类型

    题解:
    1、创建泛型对象的时候,一定要指出类型变量T的具体类型。争取让编译器检查出错误,而不是留给JVM运行的时候抛出类不匹配的异常。 2、JVM如何理解泛型概念 —— 类型擦除。事实上,JVM并不知道泛型,所有的泛型在编译阶段就已经被处理成了普通类和方法。 处理方法很简单,我们叫做类型变量T的擦除(erased) 。 总结:泛型代码与JVM ① 虚拟机中没有泛型,只有普通类和方法。 ② 在编译阶段,所有泛型类的类型参数都会被Object或者它们的限定边界来替换。(类型擦除) ③ 在继承泛型类型的时候,桥方法的合成是为了避免类型变量擦除所带来的多态灾难。 无论我们如何定义一个泛型类型,相应的都会有一个原始类型被自动提供。原始类型的名字就是擦除类型参数的泛型类型的名字。

    8、类B从类A派生,则类B可以访问类A中的( )成员?
    正确答案: A C 你的答案: A C(正确)
    public成员
    private成员
    protected成员
    所有数据成员
    所有函数成员

    题解:
    private成员只能在当前类中访问,派生类可以访问父类的public和protected属性成员

    9、下列关于系列化和反序列化描述正确的是:
    正确答案: A B 你的答案: A B (正确)
    序列化是将数据转为n个 byte序列的过程
    反序列化是将n个 byte转换为数据的过程
    将类型int转换为4 byte是反序列化过程
    将8个字节转换为long类型的数据为序列化过程

    题解:
    序列化:将数据结构转换称为二进制数据流或者文本流的过程。序列化后的数据方便在网络上传输和在硬盘上存储。
    反序列化:与序列化相反,是将二进制数据流或者文本流转换称为易于处理和阅读的数据结构的过程。
    本质其实还是一种协议,一种数据格式,方便数据的存储和传输。

    10、对 Map 的用法,正确的有:
    正确答案: C D 你的答案: C D (正确)
    new java.util.Map().put(“key” , “value”) ;
    new java.util.SortedMap().put(“key” , “value”) ;
    new java.util.HashMap().put( null , null ) ;
    new java.util.TreeMap().put( 0 , null ) ;

    题解:
    考察的是Map接口实现类的创建对象以及对象类型包含的方法。
    A选项Map属于接口类型,不可以new的方式创建对象。所以A错误。
    B选项SortedMap属于接口类型,不可以new的方式创建对象。所以B错误。
    C选项HashMap基于哈希表实现Map接口的类,并允许null的值和null键。
    D选项TreeMap通过红黑树实现Map接口的类,key不可以为null,会报NullPointerException异常,value可以为null。

    答案汇总:
    1、正确答案: D
    2、正确答案: B
    3、正确答案: C
    4、正确答案: A
    5、正确答案: C
    6、正确答案: C
    7、正确答案: D
    8、正确答案: A C
    9、正确答案: A B
    10、正确答案: C D

    以上部分题解来自牛客评论区,感谢评论区大佬的解释。

  • 相关阅读:
    模板汇总——Tarjian
    CountHunter 6101 最优贸易 强联通缩点
    POJ-3662 Telephone Lines 二分+双端队列
    EF-获取自增ID值
    EF-记录程序自动生成并执行的sql语句日志
    EF-使用迁移技术让程序自动更新数据库表结构
    EF-关于类库中EntityFramework之CodeFirst(代码优先)的操作浅析
    javascript进阶笔记(3)
    javascript进阶笔记(2)
    javascript进阶笔记(1)
  • 原文地址:https://www.cnblogs.com/lyck/p/15166583.html
Copyright © 2020-2023  润新知