2025年Java面试笔试题及答案.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

2025年Java面试笔试题及答案

一、基础语法与面向对象

1.简述Java中==与equals()的区别,并说明String类重写equals()的必要性。

==对于基本数据类型比较值是否相等,对于引用类型比较内存地址是否相同。equals()是Object类的方法,默认实现等价于==,但可通过重写实现内容比较。String类重写equals()的必要性在于:字符串的核心比较需求是内容而非地址,例如newString(abc)与abc的地址不同但内容相同,重写后能正确判断内容相等性。需注意String常量池机制会影响==的结果,直接赋值的字符串会优先使用常量池中的对象,而new创建的会在堆中新建对象。

2.分析以下代码的输出结果,并说明原因:

```java

publicclassTest{

staticclassA{

protectedintvalue=10;

publicvoidprint(){

System.out.println(A:+value);

}

}

staticclassBextendsA{

protectedintvalue=20;

@Override

publicvoidprint(){

System.out.println(B:+value);

}

}

publicstaticvoidmain(String[]args){

Aa=newB();

System.out.println(a.value);

a.print();

Bb=(B)a;

System.out.println(b.value);

}

}

```

输出结果为:

10

B:20

20

原因:Java中成员变量不支持多态,访问时取决于引用类型(编译期类型)。a是A类型引用,因此a.value访问的是A类的value字段(值为10)。而方法调用支持动态绑定,a.print()实际调用的是B类重写的print()方法,输出B类的value(但此时方法内部访问的是B类的value字段,值为20)。当强制转换为B类型后,b.value访问的是B类的value字段(值为20)。

二、集合框架与泛型

3.对比分析HashMap(JDK1.8)与ConcurrentHashMap(JDK1.8)的底层实现差异,说明ConcurrentHashMap如何保证线程安全。

HashMap底层使用数组+链表+红黑树结构。当链表长度≥8且数组长度≥64时,链表转换为红黑树;当红黑树节点数≤6时退化为链表。线程不安全,多线程环境下可能出现扩容时的循环链表(JDK1.7)或数据覆盖问题。

ConcurrentHashMap(JDK1.8)放弃了JDK1.7的分段锁(Segment)设计,采用CAS+synchronized的轻量级锁机制:

数组节点(Node)作为锁的基本单位,仅锁定发生冲突的链表或红黑树的头节点,降低锁粒度。

初始化数组时使用CAS(compareAndSwap)保证只有一个线程执行初始化。

插入元素时,若对应位置为空则通过CAS插入;若已存在节点则使用synchronized锁定该节点,再进行链表/红黑树操作。

扩容时采用协助扩容机制,其他线程在发现正在扩容时会协助迁移节点,提高并发效率。

4.编写一个泛型方法,实现对List中元素的批量替换(将所有旧元素替换为新元素),并说明类型通配符的使用限制。

参考实现:

```java

publicstaticTvoidreplaceAll(ListTlist,ToldVal,TnewVal){

if(list==null)return;

for(inti=0;ilist.size();i++){

Telement=list.get(i);

if(oldVal==null?element==null:oldVal.equals(element)){

list.set(i,newVal);

}

}

}

```

类型通配符限制:

上界通配符?extendsT:只能读取元素(视为T类型),不能写入(除null外),因为无法确定具体子类型。

下界通配符?sup

文档评论(0)

yclhgy + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档