2024年Java最新面试常问之垃圾收集器(CMS收集器 , G1收集器…),BTAJ面试有关散列(哈希)表的面试题详解

本文总结了美团、字节、腾讯等公司的面试问题,强调算法和数据结构的重要性,并推荐左程云的《程序员代码面试指南》,涵盖Java面试准备,包括各种垃圾回收器的比较和Spring框架及其微服务生态的学习资源。
摘要由CSDN通过智能技术生成

结局:总结+分享

看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多,可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

开篇有提及我可是足足背下了Java互联网工程师面试1000题,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!能读到此处的都是真爱

  • Java互联网工程师面试1000题

image.png

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。

  • 程序员代码面试指南–IT名企算法与数据结构题目最优解

image.png

  • 其余像设计模式,建议可以看看下面这4份PDF(已经整理)

image.png

  • 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。

image.png

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

为什么有这么多垃圾回收器呢?

  1. 历史的发展,java的不断更新,GC的不断改进

  2. 垃圾回收器没有好坏之分,只不过没有人能够解决所有问题,根据不同的场景使用不同的垃圾回收器(但是一般默认就够了)

垃圾的回收评价指标

  1. 回收空间的效率(如两个人打扫同一间房子,效果当然是不一样的)

  2. 回收的速度(两个人打扫房间的时间也不一样 -> 影响STW)

  3. 是否允许和应用线程并行(扫地的时候不影响其他人正常工作 -> 影响STW)

  4. 垃圾回收器是否是多线程(因为 标记/回收 都是CPU密集型操作,每个线程负责一部分,那当然效率会更高)

  5. 垃圾回收的时间是否可预期

  6. ……

STW问题可参考这篇文章,有提到

1.1.Serials收集器(新生代收集器,穿行GC)

Serial收集器是最基本、发展历史最悠久的收集器,曾经(在JDK 1.3.1之前)是虚拟机新生代收集的唯

一选择。

Serial收集器是虚拟运行在Client模式下的默认新生代收集器。

在这里插入图片描述

Serials收集器的特点和优势

特点:

他是一个单线程的收集器,“单线程”的意义并不仅仅说明它只会使用一个CPU或者一条收集线程取完成垃圾收集工作,而且当它在进行垃圾收集(GC)时,其他的工作线程也必须停下来,直到它收集结束。

优势:

因为进行GC操作是需要开销的,对于单个线程来说,那么肯定开销要小,所以对应的对于限定单个CPU的环境来说,这个收集器没有线程交互的开销,那么就可以获得更高的单线程收集效率

1.2. ParNew收集器(新生代收集器,并行GC)

ParNew收集器其实就是Serial收集器的多线程版本,除了使用多条线程进行垃圾收集之外,其余行为包

括Serial收集器可用的所有控制参数、收集算法、Stop The World、对象分配规则、回收策略等都与

Serial收集器完全一样

ParNew收集器是许多个运行在Server(服务器)模式下的虚拟机中首选的新生代收集器。

在这里插入图片描述

ParNew收集器与Serial收集器的对比分析:

在单个线程(CPU)的情况下,那当然没有比Serial收集器更好的效果,甚至由于存在线程小胡的开销,ParNew收集器通过超线程实现的两个CPU的环境中都不能百分百的可以超过Serial收集器,但是随着可以使用CPU的数量的增加,对于GC是系统资源的有效利用还是很有好处的。

3.3.Parallel Scanvenge收集器(新生代收集器,并行GC)

和上面的ParNew收集器类似,但是Parallel Scanvenge收集器的目的是为了能够控制吞吐量(也就是一轮GC下来要回收多少内存),能够进行更精确的回收控制

Parallel Scavenge收集器使用两个参数控制吞吐量:

  • XX:MaxGCPauseMillis 控制最大的垃圾收集停顿时间

  • XX:GCRatio 直接设置吞吐量的大小

Parallel Scavenge收集器的应用场景:

停顿时间越短就越适合需要与用户交互的程序,良好的响应速度能提升用户体验,而高吞吐量则可以高

效率地利用CPU时间,尽快完成程序的运算任务,主要适合在后台运算而不需要太多交互的任务。

3.4.Serial Old收集器(老年代收集器,串行GC)

Serial Old是Serial收集器的老年代版本,它同样是一个单线程收集器,使用标记-整理算法。

应用场景:

  • Client模式 Serial Old收集器的主要意义也是在于给Client模式下的虚拟机使用。

  • Server模式 如果在Server模式下,那么它主要还有两大用途:一种用途是在JDK 1.5以及之前的版本中与Parallel Scavenge收集器搭配使用,另一种用途就是作为CMS收集器的后备预案,在并发收集发生Concurrent Mode Failure时使用。

3.5. Parallel Old收集器(老年代收集器,并行GC)

Parallel Old收集器是Parallel Scavenge收集器的老年代版本,使用多线程和“标记-整理”算法。

在注重吞吐量以及CPU资源敏感的场合,都可以优先考虑Parallel Scavenge加Parallel Old收集器。

在这里插入图片描述

3.6.CMS收集器(老年代收集器,并发GC)

CMS收集器的目的就是获取最短回收停顿时间(STW)

CMS是基于“标记-清除”算法实现,步骤为:

Spring全套教学资料

Spring是Java程序员的《葵花宝典》,其中提供的各种大招,能简化我们的开发,大大提升开发效率!目前99%的公司使用了Spring,大家可以去各大招聘网站看一下,Spring算是必备技能,所以一定要掌握。

目录:

部分内容:

Spring源码

  • 第一部分 Spring 概述
  • 第二部分 核心思想
  • 第三部分 手写实现 IoC 和 AOP(自定义Spring框架)
  • 第四部分 Spring IOC 高级应用
    基础特性
    高级特性
  • 第五部分 Spring IOC源码深度剖析
    设计优雅
    设计模式
    注意:原则、方法和技巧
  • 第六部分 Spring AOP 应用
    声明事务控制
  • 第七部分 Spring AOP源码深度剖析
    必要的笔记、必要的图、通俗易懂的语言化解知识难点

脚手框架:SpringBoot技术

它的目标是简化Spring应用和服务的创建、开发与部署,简化了配置文件,使用嵌入式web服务器,含有诸多开箱即用的微服务功能,可以和spring cloud联合部署。

Spring Boot的核心思想是约定大于配置,应用只需要很少的配置即可,简化了应用开发模式。

  • SpringBoot入门
  • 配置文件
  • 日志
  • Web开发
  • Docker
  • SpringBoot与数据访问
  • 启动配置原理
  • 自定义starter

微服务架构:Spring Cloud Alibaba

同 Spring Cloud 一样,Spring Cloud Alibaba 也是一套微服务解决方案,包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

  • 微服务架构介绍
  • Spring Cloud Alibaba介绍
  • 微服务环境搭建
  • 服务治理
  • 服务容错
  • 服务网关
  • 链路追踪
  • ZipKin集成及数据持久化
  • 消息驱动
  • 短信服务
  • Nacos Confifig—服务配置
  • Seata—分布式事务
  • Dubbo—rpc通信

Spring MVC

目录:

部分内容:

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

8-1714995715548)]

[外链图片转存中…(img-esYuZKAQ-1714995715549)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 18
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值