Java经典题总结

本文总结了Java编程中的序列化与反序列化、HashMap特性、HttpServletResponse功能、Object默认方法、类型转换规则、并发同步器等内容,通过实例解析各个知识点,并提供了相关的错误选项分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

来源:牛客网

1.下列关于序列化和反序列化描述正确的是:A,B

A.序列化是将数据转为n个 byte序列的过程

B.反序列化是将n个 byte转换为数据的过程

C.将类型int转换为4  byte是反序列化过程

D.将8个字节转换为long类型的数据为序列化过程

解析:老哥的分析通俗易懂,C和D反了

在这里插入图片描述

2.在Java中,关于HashMap类的描述,以下错误的是(A)?

A.HashMap能够保证其中元素的顺序

B.HashMap允许将null用作值

C.HashMap允许将null用作键

D.HashMap使用键/值得形式保存数据

解析
HashMap是基于哈希算法来确定元素的位置(槽)的,当我们向集合中存入数据时,它会计算传入的Key的哈希值,并利用哈希值取余来确定槽的位置,与存入的先后顺序无关,所以可以认定为HashMap是无序的。因此答案A错误

3. 下面哪个不属于HttpServletResponse接口完成的功能?C

A.设置HTTP头标

B.设置cookie

C.读取路径信息

D.输出返回数据

解析:HttpServletResponse完成:设置http头标,设置cookie,设置返回数据类型,输出返回数据;读取路径信息是HttpServletRequest做的

4.下面有关java object默认的基本方法,说法错误的是?B

A.equals(Object obj) 指示某个其他对象是否与此对象“相等”

B.copy() 创建并返回此对象的一个副本

C.wait() 导致当前的线程等待,直到其他线程调用此对象的 notify() 方法或 notifyAll() 方法

D.toString() 返回一个字符串,该字符串由类名(对象是该类的一个实例)、at 标记符“@”和此对象哈希码的无符号十六进制表示组成

解析:Object中没有copy()方法,Object中是clone()

5.在这里插入图片描述

解析:这道题选B,因为count = count++;还是等于零,一直再做无用功

6.在这里插入图片描述

解析: 本题答案应为:B、C、D
------------知识点------------
Java表达式转型规则由低到高转换:
1、所有的byte,short,char型的值将被提升为int型;

2、如果有一个操作数是long型,计算结果是long型;

3、如果有一个操作数是float型,计算结果是float型;
4、如果有一个操作数是double型,计算结果是double型;
5、被fianl修饰的变量不会自动改变类型,当2个final修饰相操作时,结果会根据左边变量的类型而转化。
--------------解析--------------
语句1错误:b3=(b1+b2);自动转为int,所以正确写法为b3=(byte)(b1+b2);或者将b3定义为int;
语句2正确:b6=b4+b5;b4、b5为final类型,不会自动提升,所以和的类型视左边变量类型而定,即b6可以是任意数值类型;
语句3错误:b8=(b1+b4);虽然b4不会自动提升,但b1仍会自动提升,所以结果需要强转,b8=(byte)(b1+b4);
语句4错误:b7=(b2+b5); 同上。同时注意b7是final修饰,即只可赋值一次,便不可再改变。

7. JDK提供的用于并发编程的同步器有哪些?(A,B,C)

A.Semaphore

B.CyclicBarrier

C.CountDownLatch

D. Counter

解析
A,Java 并发库 的Semaphore 可以很轻松完成信号量控制,Semaphore可以控制某个资源可被同时访问的个数,通过 acquire() 获取一个许可,如果没有就等待,而 release() 释放一个许可。
B,CyclicBarrier 主要的方法就是一个:await()。await() 方法没被调用一次,计数便会减少1,并阻塞住当前线程。当计数减至0时,阻塞解除,所有在此 CyclicBarrier 上面阻塞的线程开始运行。
C,直译过来就是倒计数(CountDown)门闩(Latch)。倒计数不用说,门闩的意思顾名思义就是阻止前进。在这里就是指 CountDownLatch.await() 方法在倒计数为0之前会阻塞当前线程。
D,Counter不是并发编程的同步器

8. 关于下面的程序,说法正确的是: D

1.class StaticStuff
2. {
3.     static int x = 10;
4.
5.     static { x += 5; }
6.
7. public static void main(String args[])
8. {
9.     System.out.println(“x =+ StaticStuff .x);
10. }
11.    static
12.     {x /= 3; }
13.}

A.第5行和12行不能编译,因为该方法没有方法名和返回值。

B.第12 行不能编译,因为只能有一个static初始化块。

C.代码编译并执行,输出结果x = 10.

D.代码编译并执行,输出结果 x = 5.

E.代码编译并执行,输出结果 x = 15.

解析: 选D。考察的是代码执行的顺序。
第5、12行属于static修饰的静态代码块。所以A、B说法错误。
静态代码块以及静态变量自上而下的顺序依次随着类加载而执行,所以依据题目的变量初始化:

x初始为10
x+5赋值x,结果为15
x/3赋值给x,结果为5 

执行顺序为:

父类静态代码块、静态变量 ps:按声明顺序执行

子类静态代码块、静态变量 ps:按声明顺序执行

父类局部代码块、成员变量 ps:按声明顺序执行

父类构造函数

子类局部代码

9.下面有关servlet service描述错误的是?B

A.不管是post还是get方法提交过来的连接,都会在service中处理

B.doGet/doPost 则是在 javax.servlet.GenericServlet 中实现的

C.service()是在javax.servlet.Servlet接口中定义的

D.service判断请求类型,决定是调用doGet还是doPost方法

解析:doGet/doPost 则是在 javax.servlet.http.HttpServlet 中实现的

10.MS垃圾回收器在那些阶段是没用用户线程参与的 A,C

A.初始标记

B.并发标记

C.重新标记

D.并发清理

解析
CMS收集器是一种以获取最短回收停顿时间为目标的收集器,它是基于标记清除算法实现的,它的运作过程相对于其他收集器来说要更复杂一些,整个过程分为四个步骤,包括:初始标记、并发标记、重新标记、并发清除。其中初始标记、重新标记这两个步骤需要暂停整个JVM。

初始标记仅仅只是标记一下GC Roots能直接关联到的对象,速度很快。

并发标记阶段就是从GC Roots的直接关联对象开始遍历整个对象图的过程,这个过程耗时较长但是不需要停顿用户线程,可以与垃圾收集线程一起并发运行。

重新标记阶段则是为了修正并发标记期间,因用户程序继续运作而导致标记产生变动的那一部分对象的标记记录,这个阶段的停顿时间通常会比初始标记阶段稍长一些,但也远比并发标记阶段的时间短。

并发清除阶段,清理删除掉标记阶段判断的已经死亡的对象,由于不需要移动存活对象,所以这个阶段也是可以与用户线程同时并发的。

示意图如下:
在这里插入图片描述
11.以下哪种方式实现的单例是线程安全的

A.枚举

B.静态内部类

C.双检锁模式

D.饿汉式

解析解析查看去牛客此链接查看

12.后续补充,未完

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值