结局:总结+分享
看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多,可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。
开篇有提及我可是足足背下了Java互联网工程师面试1000题,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!能读到此处的都是真爱
- Java互联网工程师面试1000题
而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。
- 程序员代码面试指南–IT名企算法与数据结构题目最优解
- 其余像设计模式,建议可以看看下面这4份PDF(已经整理)
- 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。
以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!
为什么有这么多垃圾回收器呢?
-
历史的发展,java的不断更新,GC的不断改进
-
垃圾回收器没有好坏之分,只不过没有人能够解决所有问题,根据不同的场景使用不同的垃圾回收器(但是一般默认就够了)
垃圾的回收评价指标
-
回收空间的效率(如两个人打扫同一间房子,效果当然是不一样的)
-
回收的速度(两个人打扫房间的时间也不一样 -> 影响STW)
-
是否允许和应用线程并行(扫地的时候不影响其他人正常工作 -> 影响STW)
-
垃圾回收器是否是多线程(因为 标记/回收 都是CPU密集型操作,每个线程负责一部分,那当然效率会更高)
-
垃圾回收的时间是否可预期
-
……
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
目录:
部分内容:
8-1714995715548)]
[外链图片转存中…(img-esYuZKAQ-1714995715549)]