秋招 Java 面试大纲:Java+ 并发 +spring+ 数据库 +Redis+JVM+Netty 等

前言:

我相信大多 Java 开发的程序员或多或少经历过阿里的面试,也清楚阿里 Java 面试是有一定难度的,作者经历过多次阿里的面试,有满意的也有备受打击的。因此呢作者想把自己这么多次面试经历来个汇总,正值金九银十之际,希望对大家有所帮助。

阿里面试题

在阿里面试还是很舒服的,面试官觉得有难度的话会适可而止,不会让你觉得不会而感到尴尬,一面的知识也不是很难

1.HashMap 的数据结构——引出 Java7 跟 Java8 的区别

2.在什么情况下会做一个链表到红黑树的转换

3.除了数据结构之外,Java8 跟 Java7 在 HashMap 上还有什么不同

4.扩容的过程,在什么情况下会扩容

5.扩容机制中的 capacity 初始值为什么是 16,可不可以自定义成 15,为什么一定要是 2 的指数次方

6.简单介绍一下 hash 算法,它的核心性能,或者说判断一个 hash 算法好坏的指标是什么,indexFor()函数的实现

7.HashMap 为了解决什么问题?——引出哈希碰撞

8.介绍 ConcurrentHashMap 的数据结构

9.ConcurrentHashMap 可以支持多少并发线程

10.ConcurrentHashMap 属于 JOC 下的一个类,对 JOC 这个包的了解

11.是否用过 synchronized,之前是否碰到过并发问题,怎么处理

12.在 Java 技术栈方面,有没有比较擅长或者深入了解的点,是否从源码上看过一些东西

13. Netty 原理介绍下。

14. 了解过 NIO,BIO,AIO 么?介绍下异同,代码中如何使用?

15. 分布式锁用过么?用什么函数?什么使用场景?

16. 能介绍下垃圾回收机制么?

17. redis 的数据结构介绍下。项目中用过哪些?什么场景

18 幂等性是什么?如何保障?

19. 交易系统中的数据一致性咋保障?

数据库

1.对 MySQL 了解多少——引出必问知识点(划重点!!!事务和索引)

2.MySQL 用的隔离级别是什么,这个隔离级别下会出现什么问题——引出数据库的并发问题

3.MySQL 使用这种隔离级别时,是如何解决幻读问题的(引申,理解其他并发问题的解决原理)

4.MySQL 的调优机制,主要是哪些方面的调优——引出索引

5.在 MySQL 的 InnoDB 这个存储引擎下,聚集索引(或者聚簇索引)和非聚集索引这两个概念

6.MySQL 中的索引是用什么数据结构存储的——此处应该引出 B+树

7.为什么通过索引查询速度会更快一些——此处应该引出二叉树算法

二轮:

自我介绍

  1. 项目中的 mongoDB 使用场景是啥?如何部署的?怎么保证高可用性?

  2. JVM 的内存结构能介绍下么?

  3. CMS 和 G1 的优缺点?什么时候发生 FULL GC?什么时候 stop the world!

  4. 什么样的对象能当根节点?

  5. 一个类,两个函数,一读一写,写函数加 synchronized,读函数还用加么?voliate 关键字啥作用?

  6. 数据库设计时,主键咋设?自增好还是非自增好?为啥?

  7. mysql 的锁类型介绍下

  8. 线上 CPU 100%了怎么查?

  9. 写个算法,给一个数字,一个单调数组中,方法返回数组中第一个大于给定数字的下标,如果没有,返回-1。

三轮:

说实话第三轮就是比较深度的问题了,都是结合业务谈谈自己的程序思想,如果没有一定的技术和开发经验这个是回答不完整的,本人就是倒在了这一关。

  1. 如何实现一个高效的单向链表逆序输出?

  2. 已知 sqrt(2)约等于 1.414,要求不用数学库,求 sqrt(2)精确到小数点后 10 位

  3. 给定一个二叉搜索树(BST),找到树中第 K 小的节点

  4. LRU 缓存机制

  5. 关于 epoll 和 select 的区别,以下哪些说法是正确的

  6. 从 innodb 的索引结构分析,为什么索引的 key 长度不能太长

  7. 给定一个链表,删除链表的倒数第 N 个节点,并且返回链表的头结点

  8. 如果让你设计一个通用的、支持各种数据库秒级备份和恢复的系统,你会如何设计

  9. 如果让你来设计一个支持数据库、NOSQL 和大数据之间数据实时流动的数据流及处理的系统,你会考虑哪些问题?如何设计?

  10. 给定一个整数数组和一个整数,返回两个数组的索引,这两个索引指向的数字的加和等于指定的整数。需要最优的算法,分析算法的空间和时间复杂度

  11. 假如给你一个新产品,你将从哪些方面来保障它的质量?

  12. 请评估一下程序的执行结果?

腾讯面试题

Java 基础

1.JAVA 中的几种基本数据类型是什么,各自占用多少字节。

2.String 类能被继承吗,为什么。

3.String,Stringbuffer,StringBuilder 的区别。

4.ArrayList 和 LinkedList 有什么区别。

5.讲讲类的实例化顺序,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,当 new 的时候,他们的执行顺序。

6.用过哪些 Map 类,都有什么区别,HashMap 是线程安全的吗,并发下使用的 Map 是什么,他们内部原理分别是什么,比如存储方式,hashcode,扩容,默认容量等。

7.JAVA8 的 ConcurrentHashMap 为什么放弃了分段锁,有什么问题吗,如果你来设计,你如何设计。

8.有没有有顺序的 Map 实现类,如果有,他们是怎么保证有序的。

9.抽象类和接口的区别,类可以继承多个类么,接口可以继承多个接口么,类可以实现多个接口么。

10.继承和聚合的区别在哪。

11.IO 模型有哪些,讲讲你理解的 nio ,他和 bio,aio 的区别是啥,谈谈 reactor 模型。

12.反射的原理,反射创建类实例的三种方式是什么。

13.反射中,Class.forName 和 ClassLoader 区别 。

14.描述动态代理的几种实现方式,分别说出相应的优缺点。

15.动态代理与 cglib 实现的区别。

16.为什么 CGlib 方式可以对接口实现代理。

17.final 的用途。

18.写出三种单例模式实现 。

19.Java 中的 HashSet 内部是如何工作的。

20.什么是序列化,怎么序列化,为什么序列化,反序列化会遇到什么问题,如何解决。

JVM

21.什么情况下会发生栈内存溢出。

22.JVM 的内存结构,Eden 和 Survivor 比例。

23.JVM 内存为什么要分成新生代,老年代,持久代。新生代中为什么要分为 Eden 和 Survivor。

24.JVM 中一次完整的 GC 流程是怎样的,对象如何晋升到老年代,说说你知道的几种主要的 JVM 参数。

25.你知道哪几种垃圾收集器,各自的优缺点,重点讲下 cms 和 G1,包括原理,流程,优缺点。

26.垃圾回收算法的实现原理。

27.当出现了内存溢出,你怎么排错。

28.简单说说你了解的类加载器,可以打破双亲委派么,怎么打破。

29.g1 和 cms 区别,吞吐量优先和响应优先的垃圾收集器选择。

30.怎么打出线程栈信息。

开源框架

31.简单讲讲 tomcat 结构,以及其类加载器流程,线程模型等。

32.tomcat 如何调优,涉及哪些参数 。

33.讲讲 Spring 加载流程。

34.Spring AOP 的实现原理。

35.讲讲 Spring 事务的传播属性。

36.Spring 如何管理事务的。

37.说说你对 Spring 的理解,非单例注入的原理?它的生命周期?循环注入的原理,aop 的实现原理,说说 aop 中的几个术语,它们是怎么相互工作的。

38.Springmvc 中 DispatcherServlet 初始化过程。

39.netty 的线程模型,netty 如何基于 reactor 模型上实现的。

40.netty 的通讯协议是什么样的。

41.springmvc 用到的注解,作用是什么,原理。

42.springboot 启动机制

百度面试题

1、自我介绍以及项目介绍

2、spring-cloud 是否了解,spring-boot 是了解,讲一讲 bean 的生命周期

3、hashmap-1.8 后的改进,hashmap 为什么是线程不安全的

4、如何做到线程安全,concurrenthashmap 是怎么实现的

5、用到哪些的设计模式

6、ThreadLocal 用过吗

7、类的加载机制

8、JVM-内存模型

9、垃圾回收

10、redis 源码有读过吗

11. 介绍你做的项目和其中的难点?

12.反射的作用是什么?

13. 数据仓库,多线程和并发工具等?

14. 私有云,docker 和 k8s 等?

15. 了解哪些中间件,dubbo,rocketmq,mycat 等?

16. dubbo 中的 rpc 如何实现?

17. 自己实现 rpc 应该怎么做?

18. dubbo 的服务注册与发现?

19.给你一个有序整数数组,数组中的数可以是正数、负数、零,请实现一个函数,这个函数返回一个整数:返回这个数组所有数的平方值中有多少种不同的取值。

JVM 篇

JVM 是 Java 运行基础,面试时一定会遇到 JVM 的有关问题,内容相对集中,但对知识深度要求还是较高。

其中内存模型,类加载机制,GC 是重点方面。性能调优部分更偏向应用,重点突出实践能力。编译器优化执行和模式部分偏向于理论基础,重点掌握知识点。

多线程 &并发篇

Spring 篇

MyBatis 篇

Spring Boot 篇

MySQL 篇

Spring Cloud 篇

Dubbo 篇

MQ 篇

Zookeeper 篇

Redis 篇

分布式篇

网络篇

总结:

互联网大厂比较喜欢的人才特点:对技术有热情,强硬的技术基础实力;主动,善于团队协作,善于总结思考。无论是哪家公司,都很重视高并发高可用技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。

一、简答题 1.编译java程序使用什么命令?运行java使用什么命令? javac *.java java 类名 2.什么是JDK,什么是JRE,JDK与JRE有什么区别? JDK:Java Development Toolkit Java开发工具包 JRE:Java Runtime Enviorment Java运行时环境 区别:开发JAVA程序必须安装JDK,运行JAVA程序必须安装JRE。 3.为什么说JAVA语言的跨平台的?JAVA虚拟机JVM是跨平台的吗? 因为JAVA程序编译后生成的字节码文件(class文件)是跨平台的。JVM不是跨平台,在不同的操作系统上开发JAVA程序,必须安装该操作系统版本的JVM。 4.Java当中如何跳出多重循环? 使用break label; 5.JAVA的数据类型分为哪几类? 基本数据类型和引用数据类型 6.String/StringBuffer/StringBuilder的区别是什么? String:不可变 StringBuffer:可变,并且线程安全,效率差。 StringBuilder:可变,线程不安全,效率高 7.面向对象的三大特征是什么? 封装、继承、多态 8.Java实现多态性的机制是什么? 有继承 有方法重写 父类引用指向子类对象 9.什么是方法重载?什么是方法重写?方法重载与方法重写的区别? 方法重载(Overload):是指方法名字相同,参数的个数、类型、次序不同。 方法重写(Override/Overwrite):是指子类重写了从父类继承过来的方法。 区别:方法重载没有继承、属于一种静态联编技术。 方法重写有继承、属于动态联编技术。 10.什么是抽象类?什么是接口?抽象类与接口的区别?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值