首页 > 编程语言 >Java中高级面试题部分答案解析

Java中高级面试题部分答案解析

时间:2025-01-04 15:00:10浏览次数:3  
标签:面试题 Java ArrayList ConcurrentHashMap Vector 线程 中高级 方法 虚拟机

List和Set比较,各自的子类比较

对比一:Arraylist与LinkedList的比较

1.rrayList是实现了基于动态数组的数据结构,因为地址连续,一旦数据存储好了,查询操作效率会比较高(在内存里是连着放的)。

2、因为地址连续, ArrayList要移动数据,所以插入和删除操作效率比较低。

3、LinkedList基于链表的数据结构,地址是任意的,所以在开辟内存空间的时候不需要等一个连续的地址,对于新增和删除操作add和remove,LinedList比较占优势。

4、因为LinkedList要移动指针,所以查询操作性能比较低。

适用场景分析:

当需要对数据进行对此访问的情况下选用ArrayList,当需要对数据进行多次增加删除修改时采用LinkedList。

对比二:ArrayList与Vector的比较

1、Vector的方法都是同步的,是线程安全的,而ArrayList的方法不是,由于线程的同步必然要影响性能。因此,ArrayList的性能比Vector好。

2、当Vector或ArrayList中的元素超过它的初始大小时,Vector会将它的容量翻倍,而ArrayList只增加50%的大小,这样。ArrayList就有利于节约内存空间。

3、大多数情况不使用Vector,因为性能不好,但是它支持线程的同步,即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性。

4、Vector可以设置增长因子,而ArrayList不可以。

适用场景分析:

1、Vector是线程同步的,所以它也是线程安全的,而ArrayList是线程异步的,是不安全的。如果不考虑到线程的安全因素,一般用ArrayList效率比较高。

2、如果集合中的元素的数目大于目前集合数组的长度时,在集合中使用数据量比较大的数据,用Vector有一定的优势。

对比三:HashSet与TreeSet的比较

1.TreeSet 是二叉树实现的,Treeset中的数据是自动排好序的,不允许放入null值 。

2.HashSet 是哈希表实现的,HashSet中的数据是无序的,可以放入null,但只能放入一个null,两者中的值都不能重复,就如数据库中唯一约束 。

3.HashSet要求放入的对象必须实现HashCode()方法,放入的对象,是以hashcode码作为标识的,而具有相同内容的String对象,hashcode是一样,所以放入的内容不能重复。但是同一个类的对象可以放入不同的实例。

  篇幅限制下面就只能给大家展示小册部分内容了。整理了一份核心面试题包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题

 需要全套面试笔记的【点击此处即可】即可免费获取

适用场景分析:

HashSet是基于Hash算法实现的,其性能通常都优于TreeSet。我们通常都应该使用HashSet,在我们需要排序的功能时,我们才使用TreeSet。

HashMap和ConcurrentHashMap的区别

1、HashMap 不是线程安全的,而 ConcurrentHashMap 是线程安全的。

2、ConcurrentHashMap 采用锁分段技术,将整个 Hash 桶进行了分段 segment,也就是将这个大的数组分成了几个小的片段 segment,而且每个小的片段 segment 上面都有锁存在,那么在插入元素的时候就需要先找到应该插入到哪一个片段 segment,然后再在这个片段上面进行插入,而且这里还需要获取 segment 锁。

3、ConcurrentHashMap 让锁的粒度更精细一些,并发性能更好。

HashTable 和 ConcurrentHashMap 的区别

它们都可以用于多线程的环境,但是当 Hashtable 的大小增加到一定的时候,性能会急剧下降,因为迭代时需要被锁定很长的时间。因为 ConcurrentHashMap 引入了分割(segmentation),不论它变得多么大,仅仅需要锁定 map 的某个部分,而其它的线程不需要等到迭代完成才能访问map。简而言之,在迭代的过程中,ConcurrentHashMap仅仅锁定map的某个部分,而Hashtable则会锁定整个map。

String,StringBuffer和StringBuilder的区别

1、运行速度,或者说是执行速度,在这方面运行速度快慢为:StringBuilder > StringBuffer > String。

2、线程安全上,StringBuilder是线程不安全的,而StringBuffer是线程安全的。

适用场景分析:

String:适用于少量的字符串操作的情况

StringBuilder:适用于单线程下在字符缓冲区进行大量操作的情况

StringBuffer:适用多线程下在字符缓冲区进行大量操作的情况

wait和sleep的区别

1、sleep()方法是属于Thread类中的,而wait()方法,则是属于Object类中的。

2、sleep()方法导致了程序暂停执行指定的时间,让出cpu给其他线程,但是他的监控状态依然保持着,当指定的时间到了又会自动恢复运行状态。所以在调用sleep()方法的过程中,线程不会释放对象锁。

3、调用wait()方法的时候,线程会放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象调用notify()方法后本线程才进入对象锁定池准备获取对象锁进入运行状态。

JVM的内存结构

根据 JVM 规范,JVM 内存共分为虚拟机栈、堆、方法区、程序计数器、本地方法栈五个部分。

1、Java虚拟机栈:

线程私有;每个方法在执行的时候会创建一个栈帧,存储了局部变量表,操作数栈,动态连接,方法返回地址等;每个方法从调用到执行完毕,对应一个栈帧在虚拟机栈中的入栈和出栈。

2、堆:

线程共享;被所有线程共享的一块内存区域,在虚拟机启动时创建,用于存放对象实例。

3、方法区:

线程共享;被所有线程共享的一块内存区域;用于存储已被虚拟机加载的类信息,常量,静态变量等。

4、程序计数器:

线程私有;是当前线程所执行的字节码的行号指示器,每条线程都要有一个独立的程序计数器,这类内存也称为“线程私有”的内存。

5、本地方法栈:

线程私有;主要为虚拟机使用到的Native方法服务。

   篇幅限制下面就只能给大家展示小册部分内容了。整理了一份核心面试题包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题

 需要全套面试笔记的【点击此处即可】即可免费获取

标签:面试题,Java,ArrayList,ConcurrentHashMap,Vector,线程,中高级,方法,虚拟机
From: https://blog.csdn.net/2401_89221867/article/details/144929439

相关文章

  • Java面试题经典面试题220道(附答案)
    1.线程的生命周期?线程有几种状态?线程通常有五种状态,创建,就绪,运⾏、阻塞和死亡状态:        1. 新建状态(New) :新创建了一个线程对象。        2. 就绪状态(Runnable) :线程对象创建后,其他线程调⽤了该对象的start⽅法。该状态的线程位于可运⾏线程池中,变得可......
  • 让 Java 再次伟大 - 什么是 ORM 什么是 JOOQ 什么是数据库操作层?
    学会这款......
  • Java学习笔记07-加油站支付小模块
    需求:某加油站为了吸引更多的车主,推出如下活动,车主可以办理金卡或银卡。卡片信息包括:车牌号码、车主姓名、电话号码、卡片余额。金卡办理时入存金额必须>=5000元,银卡办理时入存金额必须>=2000元,金卡支付时享受8折优惠,银卡支付时享受9折优惠,金卡消费满200元可以提供打印免费洗......
  • Java包中DTO,VO, 实体类的区别
    在软件开发中,实体类、VO(ValueObject)和DTO(DataTransferObject)是常见的三种类,它们各自有不同的用途和含义。下面是它们之间的主要区别:1.实体类(EntityClass)实体类通常表示数据库中的一张表或某个持久化对象。在ORM(如Hibernate、MyBatis等)框架中,实体类用来映......
  • Spring AOP 面试题大全
    以下是SpringAOP(Aspect-OrientedProgramming,面向切面编程)面试中常见的15+道经典问题,每道问题都包含详细解答和代码示例,以便于理解与记忆。1.什么是AOP?问题:请解释什么是AOP以及其核心概念。解答:AOP是一种编程思想,用于处理程序中的横切关注点(如日志、事......
  • java8--类Scanner--文件内容输入--错误的使用方法
    Scannerin=newScanner("mygile.txt");Stringstr=in.nextLine();System.out.println(str);效果图:ps:1.没有用类Paths的静态方法get指定路径,直接在创建Scanner新对象时传入文件名做参数,使用时不会启动输入步骤,不会从键盘获取输入,执行的是赋值操作,将文件名当作字符串直......
  • 高频 Python 面试题解析(附代码解释)
    高频Python面试题解析(附代码解释)引言Python作为目前最受欢迎的编程语言之一,广泛应用于Web开发、数据分析、人工智能等领域。在面试中,Python的基础知识、数据结构、算法等方面的高频问题总是被考察。因此,在这篇文章中,我们将深入剖析一些常见的Python面试题,帮助你轻松应对面试挑......
  • 6.java方法重载和方法重写之间的区别是什么
    Java中的方法重载(MethodOverloading)和方法重写(MethodOverriding)是两个不同的概念,它们虽然名字相似,但含义和用途有显著区别。下面是它们之间的详细对比:1.定义方法重载(MethodOverloading):指在同一个类中,方法名相同但参数列表不同(参数的个数、类型或顺序不同)的情况......
  • 深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)PDF、EPUB免费下载
    适读人群:1.使用Java技术体系的中-高级开发人员2.系统调优师3.平台架构师4.准备进互联网大厂面试的Java开发人员周志明JVM新作,新增内容近50%,大厂面试知识点全覆盖。与《Java编程思想、EffectiveJava、Java核心技术》堪称“Java四大名著”电子版仅供预览,下载后24小时内务必删......
  • 科创活动|基于java的科创微应用平台小程序(源码+数据库+文档)
    科创活动|科创微应用平台小程序目录基于java的科创微应用平台小程序一、前言二、系统设计三、系统功能设计四、数据库设计 五、核心代码 六、论文参考七、最新计算机毕设选题推荐八、源码获取:博主介绍:✌️大厂码农|毕设布道师,阿里云开发社区乘风者计划专家博主,C......