最新阿里、拼多多、快手Java岗面试题269 道送答案

1,431 阅读11分钟

Java面试,是对技术知识栈的梳理、考核、复盘

每一次Java面试,其实都是一次学习机会,是对自己技术知识栈的梳理、考核、复盘。我们应该抱着学习的态度,认真对待,找到自己比较薄弱的环节,尽快去查漏补缺学习巩固。

经过一轮认真复习之后,你会发现自己的技术知识栈越来越充实,这时候再去挑战好offer,成功概率无疑会增大很多。当有机会参与心仪公司或BAT大厂面试时,你至少能够游刃有余回答大部分问题。

刷大厂面试真题,则是查漏补缺的最好方法之一。

以下最新总结的2019阿里集团Java岗面试题目,分享给需要的读者朋友。

最新总结的2019阿里4大核心事业部面试题

【阿里天猫、蚂蚁、钉钉面试题目】

1、微信红包怎么实现。

2、海量数据分析。

3、测试职位问的线程安全和非线程安全。

4、HTTP2.0、thrift。

5、面试电话沟通可能先让自我介绍。

6、分布式事务一致性。

7、nio的底层实现。

8、jvm基础是必问的,jvm GC原理,JVM怎么回收内存。

9、Java是什么。

10、API接口与SDI接口的区别(API是提供给别人的接口)。

11、dubbo如何一条链接并发多个调用。Dubbo的原理,序列化相关问题。

12、用过哪些中间件。

13、做过工作流引擎没有。

14、以前的工作经历,自己觉得出彩的地方(钉钉)

15、线程池的一些原理,锁的机制升降级(天猫、蚂蚁)

16、从系统层面考虑,分布式从哪些纬度考虑(天猫)

17、Hadoop底层怎么实现(天猫)

18、threadLocal,线程池,hashMap/hashTable/coccurentHashMap等(天猫)

19、秒杀系统的设计(天猫)

20、虚拟机,IO相关知识点(天猫)

21、Linux的命令(天猫)

22、一个整形数组,给定一个数,在数组中找出两个数的和等于这个数,并打印出来,我写的时间复杂度高,要求O(n)。(天猫)

23、n个整数,找出连续的m个数加和是最大。(天猫)

24、更重视开源技术(蚂蚁金服上海)

25、数据库锁隐原理(蚂蚁金服网商)

26、1000个线程同时运行,怎么防止不卡(航旅)

27、并列的并发消费问题(航旅)

28、高并发量大的话怎么处理热点,数据等(蚂蚁金服)

29、如何获取一个本地服务器上可用的端口

30、流量控制相关问题(蚂蚁金服)

31、数据库TPS是多少,是否进行测试过(天猫)

32、缓存击穿有哪些方案解决(天猫)

33、Java怎么挖取回收器相关原理(财富)

34、Java的集合都有哪些,都有什么特点(信息平台)

35、分布式锁,redis缓存,spring aop,系统架构图,MySQL的特性(信息平台)

36、场景,同时给10万个人发工资,怎么样设计并发方案,能确保在1分钟内全部发完 打个比方会提出类似的场景(信息平台)

【阿里巴巴面试题目】

1、java事件机制包括哪三个部分?分别介绍。

2、为什么要使用线程池?

3、线程池有什么作用?

4、说说几种常见的线程池及使用场景。

5、线程池都有哪几种工作队列?

6、怎么理解无界队列和有界队列?

7、线程池中的几种重要的参数及流程说明。

8、什么是反射机制?

9、说说反射机制的作用。

10、反射机制会不会有性能问题?

11、你怎么理解http协议?

12、说说http协议的工作流程。

13、http有哪些请求提交方式?

14、http中的200,302,403,404,500,503都代表什么状态?

15、http get和post有什么区别?

16、你怎么理解cookie和session,有哪些不同点?

17、什么是web缓存?有什么优点?

18、什么是https,说说https的工作原理?

19、什么是http代理服务器,有什么用?

20、什么是虚拟主机及实现原理?

21、什么是Java虚拟机,为什么要使用?

22、说说Java虚拟机的生命周期及体系结构。

23、说一说Java内存区域。

24、什么是分布式系统?

25、分布式系统你会考虑哪些方面?

26、讲一讲TCP协议的三次握手和四次挥手流程。

27、为什么TCP建立连接协议是三次握手,而关闭连接却是四次握手呢?为什么不能用两次握手进行连接?

28、为什么TCP TIME_WAIT状态还需要等2MSL后才能返回到CLOSED状态?

29、什么是DoS、DDoS、DRDoS攻击?如何防御?

30、描述一下Java异常层次结构。

31、什么是检查异常,不受检查异常,运行时异常?并分别举例说明。

32、finally块一定会执行吗?

33、正常情况下,当在try块或catch块中遇到return语句时,finally语句块在方法返回之前还是之后被执行?

34、try、catch、finally语句块的执行顺序。

35、Java虚拟机中,数据类型可以分为哪几类?

36、怎么理解栈、堆?堆中存什么?栈中存什么?

37、为什么要把堆和栈区分出来呢?栈中不是也可以存储数据吗?

38、在Java中,什么是是栈的起始点,同是也是程序的起始点?

39、为什么不把基本类型放堆中呢?

40、Java中的参数传递时传值呢?还是传引用?

41、Java中有没有指针的概念?

42、Java中,栈的大小通过什么参数来设置?

43、一个空Object对象的占多大空间?

44、对象引用类型分为哪几类?

45、讲一讲垃圾回收算法。

46、如何解决内存碎片的问题?

47、如何解决同时存在的对象创建和对象回收问题?

48、讲一讲内存分代及生命周期。

49、什么情况下触发垃圾回收?

50、如何选择合适的垃圾收集算法?

51、JVM中最大堆大小有没有限制?

52、堆大小通过什么参数设置?

53、JVM有哪三种垃圾回收器?

54、吞吐量优先选择什么垃圾回收器?响应时间优先呢?

55、如何进行JVM调优?有哪些方法?

56、如何理解内存泄漏问题?有哪些情况会导致内存泄露?如何解决?

57、从分布式系统部署角度考虑,分哪几层?

58、如何解决业务层的数据访问问题?

59、为了解决数据库服务器的负担,如何做数据库的分布?

60、什么是著名的拜占庭将军问题?

61、为什么说TCP/IP协议是不可靠的?

62、讲讲CAP理念。

63、怎么理解强一致性、单调一致性和最终一致性?

64、分布式系统设计你会考虑哪些策略?

65、最常见的数据分布方式是什么?

66、谈一谈一致性哈希算法。

67、paxos是什么?

68、什么是Lease机制?

69、如何理解选主算法?

70、OSI有哪七层模型?TCP/IP是哪四层模型。

拼多多Java后端团队面试题:epoll+集群+事务隔离+Kafka+分布式等

一面

  1. 自我介绍
  2. 介绍一下mysql索引?为什么用B+树?
  3. 网络IO模型?什么是多路复用IO?select和epoll的差别?select具体过程?
  4. java类加载机制?双亲委派模型的好处?
  5. 进程和线程的区别?线程是不是越多越好,为什么?操作系统怎么调度的,调度算法?java中cpu调度是线程还是进程?
  6. 数据库事务?隔离级别?
  7. java线程变量怎么实现的?内存模型?
  8. 手撕代码
  9. 用数组模拟循环链表
  10. 堆排序实现
  11. JAVA并发包组件了解多少
  12. 线程的一个状态转换图
  13. HashMap和HashTable以及CocurrentHashMap详细说明
  14. SpringMVC的整个执行流程

二面

  1. 自我介绍
  2. 数据库索引?B+树?为什么要建索引?什么样的字段需要建索引,建索引的时候一般考虑什么?怎么解决分库分表?
  3. 数据库事务特点?事务隔离级别?项目中的事务实现?脏读、不可重复读、幻读各举个例子?
  4. Spring bean的生命周期?默认创建的模式是什么?不想单例怎么办?
  5. 谈谈Kafka和ZooKeeper了解情况?
  6. 设计模式,单例模式,怎么保证线程安全?锁效率太低,怎么提高效率?CAS?CAS本质是什么?什么是原子性?Compare and Swap,为什么能保证原子性(涉及到CPU指令)?分布式锁?
  7. 还有什么设计模式?工厂模式有几种,都讲讲?
  8. 数据库表怎么设计的?数据库范式?设计的过程中需要注意什么?enum类型的值一般怎么存?如果有一个十几位的小数为了不丢失精度怎么存?tinyint几个字节,int几个字节?

三面

  1. 项目介绍
  2. Redis简要介绍下,有哪些常用的数据结构?
  3. Redis是单线程的?Redis为什么查询数据这么快?
  4. Redis并发竞争key如何来解决?
  5. 有接触过哪些消息队列中间件?如何来选型?
  6. 谈谈你的SOA以及微服务的理解?
  7. 具体谈谈Spring Cloud服务和注册?
  8. 分布式场景面临的最大挑战是什么?
  9. 分布式场景数据同步如何来解决?

以上就是拼多多后端Java团队面试题。

快手Java4面题目:策略模式+红黑树+Java锁+Redis+Kafka等分布式

一面(一个小时十分钟)

1.自我介绍

2.说说B+树和B树的区别,优缺点等?

3聊聊Spring,主要IOC等等

4多线程JUC包下的一些常见的类,比如CountDownLatch、Semaphore等

5.锁的概念,锁相关的关键字,volatile,synchronized。还比较了ReentrantLock与synchronized。

6.你了解哪些收集器?CMS和G1。详细谈谈G1的优点?什么时候进行Full GC呢?

7.Spring中涉及的一些设计模式

8.算法题:无序数列中求第k大的数(维护最小堆,然后依次遍历,与堆顶比较)

9.MySQL创建索引的原则,好处

10. 怎么实现一个线程安全的计数器?

二面(四十多分钟)

1. 设计模式:讲了单例,工厂方法,抽象工厂,策略模式,观察者模式,代理模式,还顺便讲了下spring动态代理的实现原理

2. 线程池有哪些参数?分别有什么用?如果任务数超过的核心线程数,会发生什么?阻塞队列大小是多少?

3. HashMap的底层数据结构

4. 红黑树的具体结构及实现,红黑树与查找树的区别体现

5. 接着聊ConcurrentHashMap,底层实现

6. HashMap哈希函数的认识,JDK1.8采用的hash函数

7. 数据库索引,索引底层的实现,B+树的结构以及与普通查找树的优点

9. TCP三次握手四次挥手,四次挥手过程中服务端的哪几种状态,哪几种包

10. 已经有一个查询好友的接口,设计一个微信朋友圈,可以实现发表朋友圈,添加评论,查看评论等功能。主要是设计数据结构

三面(50分钟:主要分布式这块)

  1. 你对快手的了解,和抖音的区别,聊项目
  2. 项目中用到dubbo?那你说说什么是rpc框架?和http调用的区别是什么?
  3. Redis有哪些数据结构?持久化方案和区别?
  4. Redis哨兵、集群的设计原理和区别?
  5. Redis缓存和数据库会存在一致性问题吗?怎么解决
  6. Kafka怎么保证数据可靠性?讲了生产者端发送消息到broker持久化,分区和副本机制,消费者消费消息的at-least-once和at-most-once?怎么实现Exactly-Once?

HR面:

常规的面试流程了,主要就是自己优缺点,以及未来的职业发展,以及薪资这块。

以上就是快手技术三面和HR面试题目,以下最新总结的最全2019阿里集团资深Java必考题范围和答案,仅用于参考~

最新阿里、拼多多、快手Java岗面试题269 道送答案

最新阿里、拼多多、快手Java岗面试题269 道送答案

最新阿里、拼多多、快手Java岗面试题269 道送答案

最新阿里、拼多多、快手Java岗面试题269 道送答案