首页 课程 师资 教程 报名

Java面试如何难?Java面试总结

  • 2019-12-06 13:35:26
  • 1983次 动力节点


 

 作为一名优秀的程序员,技术面试都是不可避免的一个环节,一般技术面试官都会通过自己的方式去考察程序员的技术功底与基础理论知识。

 如果你参加过一些大厂面试,肯定会遇到一些这样的问题:

1、看你项目都用的框架,熟悉Spring、mybatis等框架实现原理吗?

2、 看你上面有接触过消息中间件,负载均衡、RPC框架等技术吗,MySQL分库分表有做过吗?

3、 分布式架构设计,Redis分布式锁呢?

  是不是看上去很难,是不是和自己准备的“题库”中的问题不一样?不知道从何处下手?如果你有这种感觉,那么说明你的技术还需要继续修炼。

  面对如此多的技术面试,怎么样才能说自己的技术已经过关了呢?

20 拷贝.jpg

一、开场白

  自我介绍,项目经验(介绍下自己最满意的,有技术亮点的项目或平台,重点介绍下自己负责那部分的技术细节;这一块主要考察应聘者对自己做过的事情是否有清晰的描述,判断做的事情的复杂度)

2、JVM

  垃圾回收算法有几种类型? 他们对应的优缺点又是什么?

  类的加载过程是什么?简单描述一下每个步骤

JVM 预定义的类加载器有哪几种?分别什么作用?

  什么是双亲委派模式?有什么作用?

  什么是内存溢出, 内存泄露? 他们的区别是什么?

  引起类加载操作的行为有哪些?

  介绍一下 JVM 提供的常用工具

Full GC 、 Major GC 、Minor GC 之间区别?

  什么时候触发 Full GC ?

...

3、Java并发

  什么是可重入锁、乐观锁、悲观锁、公平锁、非公平锁、独占锁、共享锁?

  讲讲ThreadLocal 的实现原理?

ThreadLocal 作为变量的线程隔离方式,其内部是如何做的?

  说说InheritableThreadLocal 的实现原理?

  并发包中锁的实现底层(对AQS的理解)?

  讲讲独占锁 ReentrantLock 原理?

4、Java集合

HashSet 和 TreeSet 有什么区别?

HashSet 的底层实现是什么?

LinkedHashMap 的实现原理?

  为什么集合类没有实现 Cloneable 和 Serializable 接口?

  什么是迭代器 (Iterator)?

Iterator 和 ListIterator 的区别是什么?

29 拷贝.jpg

5、Spring全家桶

Spring bean的生命周期能不能结合源码回答一下这个问题、或者结合一下bean的生命的意义来回答,就是Spring为什么需要找个生命周期

Spring容器当中包含了哪些常用组件(至少说5个),作用是什么,场景是什么;比如BeanDefinition;再比如BeanDefinitionMap

Spring自动注入的原理是什么?能不能从源码来说明一下这个问题;我们常常说的自动注入,到底怎么注入的?有什么坑?怎么让你一个属性不自动注入

Spring源码当中如何来搞定循环依赖的?Spring支持循环依赖?生命情况不支持?支持的原理是什么?能不能从源码来说明一下?

  如何来二次扩展Spring,比如自定义一个实现自动注入的注解;不使用@Autowried,自己如何开发一个@XXX来完成自动注入?

mybatis源码当中利用了Spirng的那些扩展?mybatis扩展Spring之后有哪些问题是无法解决的?比如二级缓存怎么解决

eureka源码当中如何扩展的Spring?比如怎么动态插拔eureka的功能,利用了Spring的那个技术点,或者从源码说一下

6、Redis

Redis 持久化机制有哪些? 区别是什么?优缺点是什么?

Redis支持的数据类型

  为什么 Redis 需要把所有数据放到内存中?

Redis 是单线程的吗?

Redis 的缓存失效策略有哪几种?

  什么是缓存命中率?提高缓存命中率的方法有哪些?

Redis全局命令及数据库管理

Redis设计订单应用场景

Redis缓存雪崩讲讲看?

  什么是缓存穿透?

Redis重启时加载AOF与RDB的顺序

7.中间件

Dubbo完整的一次调用链路介绍;

Dubbo支持几种负载均衡策略?

Dubbo Provider服务提供者要控制执行并发请求上限,具体怎么做?

Dubbo启动的时候支持几种配置方式?

  了解几种消息中间件产品?各产品的优缺点介绍;

  消息中间件如何保证消息的一致性和如何进行消息的重试机制?

Spring Cloud熔断机制介绍;

Spring Cloud对比下Dubbo,什么场景下该使用Spring Cloud?

8、分布式

  消息中间件如何解决消息丢失问题

Dubbo的服务请求失败怎么处理

  重连机制会不会造成错误

  对分布式事务的理解

  如何实现负载均衡,有哪些算法可以实现?

Zookeeper的用途,选举的原理是什么?

  数据的垂直拆分水平拆分。

zookeeper原理和适用场景

zookeeper watch机制

redis/zk节点宕机如何处理

  分布式集群下如何做到唯一序列号

  如何做一个分布式锁

  用过哪些MQ,怎么用的,和其他mq比较有什么优缺点,MQ的连接是线程安全的吗

MQ系统的数据如何保证不丢失

  列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问题。

9、数据库

MySQL InnoDB存储的文件结构

  索引树是如何维护的?

  数据库自增主键可能的问题

MySQL的几种优化

mysql索引为什么使用B+树

  数据库锁表的相关处理

  索引失效场景

  高并发下如何做到安全的修改同一行数据,乐观锁和悲观锁是什么,INNODB的行级锁有哪2种,解释其含义

  数据库会死锁吗,举一个死锁的例子,mysql怎么解决死锁

       以上就是动力节点Java培训机构小编介绍的“Java面试如何难?Java面试总结”的内容,希望对大家有帮助,如有疑问,请在线咨询,有专业老师随时为你服务。

相关推荐

最新最全java面试题及答案(初级到高级)

史上最全的中高级JAVA工程师面试题及答案汇总

Java高级开发工程师面试题

2019史上最全java面试题题库大全800题

哪有资深java工程师面试题

 

 

选你想看

你适合学Java吗?4大专业测评方法

代码逻辑 吸收能力 技术学习能力 综合素质

先测评确定适合在学习

在线申请免费测试名额
价值1998元实验班免费学
姓名
手机
提交