Java日常练习题|Java日常练习题,每天进步一点点(18)

目录

  • 1、main 方法是 Java Application 程序执行的入口点,以下描述哪项是合法的()。
  • 2、一般情况下,以下哪个选项不是关系数据模型与对象模型之间匹配关系?
  • 3、下列关于修饰符混用的说法,错误的是( )
  • 4、某程序要求每次输入只能是正整数,并且每次输入的数值要求必须是100的倍数且小于等于500,则下列哪个是正确的无效等价类( )
  • 5、根据以下代码段,下列说法中正确的是( )。
  • 6、在创建派生类对象,构造函数的执行顺序()
  • 7、关于下面的一段代码,以下哪些说法是正确的:
  • 8、针对以下代码,哪些选项执行后是true的:()
  • 9、以下哪些jvm的垃圾回收方式采用的是复制算法回收
  • 10、局部内部类可以用哪些修饰符修饰?
    • 答案汇总:
  • 总结
    承蒙各位厚爱,我们一起每天进步一点点!(鼠标选中空白处查看答案)

    1、main 方法是 Java Application 程序执行的入口点,以下描述哪项是合法的()。
    正确答案: B

    public static void main( )

    public static void main( String args[] )

    public static int main(String [] arg )

    public void main(String arg[] )
    题解:
    方法的名字必须是main,方法必须是public static void 类型的,方法必须接收一个字符串数组的参数 string[] args 和string args[]相同

    2、一般情况下,以下哪个选项不是关系数据模型与对象模型之间匹配关系?
    正确答案: D
    表对应类

    记录对应对象

    表的字段对应类的属性

    表之间的参考关系对应类之间的依赖关系
    题解:
    一般关系数据模型和对象数据模型之间有以下对应关系:表对应类,记录对应对象,表的字段对应类的属性。类与类之间的关系主要体现在表与表之间的关系进行操作,它们都是对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many

    3、下列关于修饰符混用的说法,错误的是( )
    正确答案: D

    abstract不能与final并列修饰同一个类

    abstract类中不应该有private的成员

    abstract方法必须在abstract类或接口中

    static方法中能直接调用类里的非static的属性
    题解:
    1、abstract不能与final并列修饰同一个类 对的。
    2、abstract类中不应该有private的成员 对的 :abstract类中可以有private 但是不应该有。
    3、abstract方法必须在abstract类或接口中 对的 : 若类中方法有abstract修饰的,该类必须abstract修改。接口方法默认public abstract。
    4、static方法中能处理非static的属性 错误 :在JVM中static方法在静态区,静态区无法调用非静态区属性。

    4、某程序要求每次输入只能是正整数,并且每次输入的数值要求必须是100的倍数且小于等于500,则下列哪个是正确的无效等价类( )
    正确答案: D

    (0,100)、(100,200)、(200,300)、(300,400)、(400,500)、(500,+∞);

    (500,+∞)

    (500,+∞)、任意大于0小于500的非100倍数的整数;

    (-∞,100)、(100,200)、(200,300)、(300,400)、(400,500)、(500,+∞);
    题解:
    无效等价类和有效等价类相反,即不满足程序输入要求或者无效的输入数据构成的集合。

    5、根据以下代码段,下列说法中正确的是( )。
    public class Parent {

    private void m1(){}

    void m2(){}

    protected void m3(){}

    public static void m4(){}

    }

    正确答案: C

    子类中一定能够继承和覆盖Parent类的m1方法

    子类中一定能够继承和覆盖Parent类的m2方法

    子类中一定能够继承和覆盖Parent类的m3方法

    子类中一定能够继承和覆盖Parent类的m4方法
    题解:
    通过继承,子类可以拥有所有父类对其可见的方法和域
    A.私有方法只能在本类中可见,故不能继承,A错误
    B.缺省访问修饰符只在本包中可见,在外包中不可见,B错误
    C.保护修饰符凡是继承自该类的子类都能访问,当然可被继承覆盖;C正确
    D.static修饰的成员属于类成员,父类字段或方法只能被子类同名字段或方法遮蔽,不能被继承覆盖,D错误

    6、在创建派生类对象,构造函数的执行顺序()
    正确答案: A

    基类构造函数,派生类对象成员构造函数,派生类本身的构造函数

    派生类本身的构造函数,基类构造函数,对象成员构造函数

    基类构造函数,派生类本身的构造函数,派生类对象成员构造函数

    对象成员构造函数,基类构造函数,派生类本身的构造函数
    题解:
    类的初始化过程也就是方法执行的过程。
    父类的静态域-子类的静态域 父类的非静态域-父类的构造函数 子类的非静态域-子类的构造函数 规律就是 父类先于子类 静态的先于非静态的
    其中静态域包含静态代码块与静态方法,这个谁在前面,则先执行谁。
    非静态域同理

    7、关于下面的一段代码,以下哪些说法是正确的:
    public static void main(String[] args) {String a = new String("myString"); String b = "myString"; String c = "my" + "String"; String d = c; System.out.print(a == b); System.out.print(a == c); System.out.print(b == c); System.out.print(b == d); }

    正确答案: A D

    System.out.print(a == b)打印出来的是false

    System.out.print(a == c)打印出来的是true

    System.out.print(b == c)打印出来的是false

    System.out.print(b == d)打印出来的是true
    题解:
    A:a指向堆内存,b指向常量池,因此地址不相等,false
    B:java有常量优化机制,c也指向常量池,且与b指向同一个,则a与c地址不相等,false;
    C:b与c地址相等,true
    D:d是c的副本,地址相同,所以b与d地址相等,true

    8、针对以下代码,哪些选项执行后是true的:()
    class CompareReference{public static void main(String [] args){float f=42.0f; float f1[]=new float[2]; float f2[]=new float[2]; float[] f3=f1; long x=42; f1[0]=42.0f; }}

    正确答案: B C

    f1==f2

    x==f1[0]

    f1==f3

    f2==f1[1]
    题解:
    B选项:x == f1[0] ,x是long类型,与float类型对比属于低精度,所以x要向高精度的float类型转型再比较,故相等;
    C选项:f1 == f3,f3没有new创建,而是由f1赋值,所以f3地址是指向f1的,f1值改变,相当于改变f3值,所以相等。

    9、以下哪些jvm的垃圾回收方式采用的是复制算法回收
    正确答案: A D

    新生代串行收集器

    老年代串行收集器

    并行收集器

    新生代并行回收收集器

    老年代并行回收收集器

    cms收集器
    题解:
    两个最基本的java回收算法:复制算法和标记清理算法
    复制算法:两个区域A和B,初始对象在A,继续存活的对象被转移到B。此为新生代最常用的算法
    标记清理:一块区域,标记可达对象(可达性分析),然后回收不可达对象,会出现碎片,那么引出
    标记-整理算法:多了碎片整理,整理出更大的内存放更大的对象
    两个概念:新生代和年老代
    新生代:初始对象,生命周期短的
    永久代:长时间存在的对象
    整个java的垃圾回收是新生代和年老代的协作,这种叫做分代回收。
    P.S:Serial New收集器是针对新生代的收集器,采用的是复制算法
    Parallel New(并行)收集器,新生代采用复制算法,老年代采用标记整理
    Parallel Scavenge(并行)收集器,针对新生代,采用复制收集算法
    Serial Old(串行)收集器,新生代采用复制,老年代采用标记整理
    Parallel Old(并行)收集器,针对老年代,标记整理
    CMS收集器,基于标记清理
    G1收集器:整体上是基于标记 整理 ,局部采用复制
    综上:新生代基本采用复制算法,老年代采用标记整理算法。cms采用标记清理。

    10、局部内部类可以用哪些修饰符修饰?
    正确答案: C D

    public

    private

    abstract

    final
    题解:
    局部内部类是放在代码块或方法中的,不能有访问控制修饰符,且不能用static修饰

    答案汇总:

    1、正确答案: B

    2、正确答案: D

    3、正确答案: D

    4、正确答案: D

    5、正确答案: C

    6、正确答案: A

    7、正确答案: A D

    8、正确答案: B C

    9、正确答案: A D

    10、正确答案: C D

    总结 【Java日常练习题|Java日常练习题,每天进步一点点(18)】本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

      推荐阅读