日常Java练习题(每天进步一点点系列)

2021/5/25 14:27:31

本文主要是介绍日常Java练习题(每天进步一点点系列),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

提示:好多小伙伴反映,直接看到答案不太好,那我把答案的颜色设置为透明,答案位置还是在题目后面,需要鼠标选中才能看见(操作如下图),同时为了手机端的小伙伴(手机端也可以长按选中查看),我还会把所有答案放到文章最下面,希望给每天进步一点点的小伙伴更好的体验。今天来迟了,对等待的朋友们说声抱歉[求原谅],文章末尾有为大家争取到的CSDN官方独家出品的【Java工程师知识图谱】限时福利优惠,为成长助力!加油!天天进步一点点!
在这里插入图片描述

1、有以下代码片段:
String str1=“hello”;
String str2=“he”+ new String(“llo”);
System.out.println(str1==str2);
请问输出的结果是:
正确答案: D 你的答案: D (正确)
true
都不对
null
false

题解:
String str1=“hello”; 这样创建字符串是存在于常量池中
String str2=new String(“hello”); str2存在于堆中,
==是验证两个对象是否是一个(内存地址是否相同),所以是false
用+拼接字符串时会创建一个新对象再返回。

2、HashMap的数据结构是怎样的?
正确答案: C 你的答案: C (正确)
数组
链表
数组+链表
二叉树

题解:
HashMap 由数组+链表组成的,数组是 HashMap 的主体,链表则是主要为了解决哈希冲突而存在的
HashMap内部包含了一个默认大小为 16 Entry 类型的数组 table,其中每个Entry 是一个链表,当链表长度大于等于 8 时会将链表转换为红黑树。

3、关于下面的程序,说法正确的是:

class StaticStuff
{
    static int x = 10;

    static { x += 5; }

    public static void main(String args[])
    {
        System.out.println(“x = ” + StaticStuff .x);
    }
    static 
    {x /= 3; }
}

正确答案: D 你的答案: D (正确)
第5行和12行不能编译,因为该方法没有方法名和返回值。
第12 行不能编译,因为只能有一个static初始化块。
代码编译并执行,输出结果x = 10.
代码编译并执行,输出结果 x = 5.
代码编译并执行,输出结果 x = 15.

题解:
第5、12行属于static修饰的静态代码块。所以A、B说法错误。
静态代码块以及静态变量自上而下的顺序依次随着类加载而执行,所以依据题目的变量初始化:
x初始为10
x+5赋值x,结果为15
x/3赋值给x,结果为5

4、枚举(enum)属于原始数据类型(primitive type)。
正确答案: B 你的答案: B(正确)
正确
错误

题解:
在Java中,变量有两种类型,一种是原始类型,一种是引用类型。
原始类型一共有8种,它们分别是char,boolean,byte,short,int,long,float,double。在Java API中,有它们对应的包装类,分别是(首字母大写)Character,Boolean,Byte,Short,Integer,Long,Float,Double(char,int的变化稍微大点)。
JAVA JVM对于不同的原始类型会分配不同的存储空间,具体分配如下:
byte : 1个字节 8位
最大值: 127 (有符号)
short : 2个字节 16位 32767
int : 4个字节 32位 2147483647
long: 8个字节 64位 9223372036854775807
float: 4个字节 32位 3.4028235E38
double:8个字节 64位 1.7976931348623157E308
枚举(enum)类型是Java 5新增的特性,它是一种新的类型,允许用常量来表示特定的数据片断,而且全部都以类型安全的形式来表示,是特殊的类,可以拥有成员变量和方法。

5、如下代码的输出是

package Test;
public class Test {
    private static void test(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            try {
                if (arr[i] % 2 == 0) {
                    throw new NullPointerException();
                } else {
                    System.out.print(i);
                }
            } finally {
                System.out.print("e");
            }
        }
    }
 
    public static void main(String[]args) {
        try {
            test(new int[] {0, 1, 2, 3, 4, 5});
        } catch (Exception e) {
            System.out.print("E");
        }
    }
 
}

正确答案: B 你的答案: B (正确)
编译出错
eE
Ee
eE1eE3eE5
Ee1Ee3Ee5

题解:
会先进到test(new int[] {0, 1, 2, 3, 4, 5});这里,进入test方法,然后if成立,throw new NullPointerException();但是此时并不会立马返回,会先把test方法中的finally执行,输出e然后回到main进到catch中输出E,所以输出eE

6、设有下面两个赋值语句:
a = Integer.parseInt(“1024”);
b = Integer.valueOf(“1024”).intValue();
下述说法正确的是()
正确答案: D 你的答案: D (正确)
a是整数类型变量,b是整数类对象。
a是整数类对象,b是整数类型变量。
a和b都是整数类对象并且它们的值相等。
a和b都是整数类型变量并且它们的值相等。

题解:
Integer对象的方法
Integer.parseInt("");是将字符串类型转换为int的基础数据类型
Integer.valueOf("")是将字符串类型数据转换为Integer对象
Integer.intValue();是将Integer对象中的数据取出,返回一个基础数据类型int
在源码中这两个方法返回的都是int 也就是说都是整数类型变量。所以应该选D

7、关于Java语言描述正确的是? ( )
正确答案: B 你的答案: B (正确)
java和C++都保留了指针
java和C++都有三个特征:封装、继承和多态
java的垃圾回收机制是指程序结束时系统自动回收内存
以上说法都不正确

题解:
送分题
A:Java没有指针,只有引用。
B:c是面向过程,java和c++都是面向对象,面向对象的三大特征是:封装、继承、多态。
C:并不是程序结束的时候进行GC,GC的时间是不确定的,且GC的过程需要经过可达性分析,一个对象只有被标记两次才会被GC。
下图是一个对象被GC的全过程。

8、Integer i = 42;
Long l = 42l;
Double d = 42.0;
下面为true的是
正确答案: G 你的答案: G (正确)
A:(i == l)
B:(i == d)
C:(l == d)
D:i.equals(d)
E:d.equals(l)
F:i.equals(l)
G:l.equals(42L)

题解:
ABC3 个选项很明显,不同类型引用的 == 比较,会出现编译错误,不能比较。
DEF 调用 equals 方法,因为此方法先是比较类型,而 i , d , l 是不同的类型,所以返回假。
选项 G ,会自动装箱,将 42L 装箱成 Long 类型,所以调用 equals 方法时,类型相同,且值也相同,因此返回真。

9、关于equals和hashCode描述正确的是 ()
正确答案: A B C 你的答案: A B C (正确)
两个obj,如果equals()相等,hashCode()一定相等(符合代码规范的情况下)
两个obj,如果hashCode()相等,equals()不一定相等
两个不同的obj, hashCode()可能相等
其他都不对

题解:
hashCode()的存在是为了查找的快捷性,用于在散列存储结构中确定对象的存储地址
如果两个对象 equals相等,则 hashCode()也一定相等
如果 equals方法被重写,则 hashCode()也应该被重写
如果两个对象的 hashCode()相等, equals()方法不一定相等
equals方法没有重写,比较的就是应用类型的变量所指向的对象的地址

10、有关finally语句块说法正确的是( )
正确答案: A B C 你的答案: A B C (正确)
不管catch是否捕获异常,finally语句块都是要被执行的
在try语句块或catch语句块中执行到System.exit(0)直接退出程序
finally块中的return语句会覆盖try块中的return返回
finally 语句块在 catch语句块中的return语句之前执行

题解:
D不是return之前,是return执行完成之前,return表达式的结果会暂时保存起来,不会被改变

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

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

CSDN官方独家出品的【Java工程师知识图谱】限时福利优惠,详情使用微信扫码查看,成长的路上有人给领路还是挺好的,利用知识图谱体系的学起来,加油,每天进步一点点!

在这里插入图片描述

每天进步一点点!
不进则退!

看完如果对你有帮助,感谢点赞支持!
如果你是电脑端,看到右下角的 “一键三连” 了吗,没错点它[哈哈]

在这里插入图片描述
加油!

共同努力!

Keafmd



这篇关于日常Java练习题(每天进步一点点系列)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程