硬核!啃完410页java面试手册,三面阿里巴巴,5月成功入职研发部

简介: 面试前我主要是在牛客网看大家的面经进行查漏补缺,所以面试完后也想记录下来,权当给大家提供点信息吧。

本文作者:牛客网来者可追

面试前我主要是在牛客网看大家的面经进行查漏补缺,所以面试完后也想记录下来,权当给大家提供点信息吧。

面试过了挺久了,记忆也有点混乱,争取想到多少就记下来多少(文末附答案以及大厂java核心面试手册

阿里一面:

1、请简单介绍一下自己。

2、项目参与的核心设计有哪些?有没有遇到过问题,是怎样去解决的?

3、ArrayList和LinkedList,它们的底层是什么?

4、HashMap及线程安全的ConcurrentHashMap,以及各自优劣势;

5、Java是如何实现线程安全的?

6、Synchronized与Lock相比,哪个更加好?

7、HashMap中的get()方法是如何实现的?

8、HashMap可以用在哪些场景?

9、JVM,垃圾回收机制,还有内存划分等;

10、SQL优化,常用的索引?

11、还有什么问题需要问的?

阿里二面:

1、自我介绍,然后问做过哪些Java开发相关的项目。

2、问我对哪些技术比较熟悉?

3、多线程状态图,状态如何流转?大概说一说;

4、问了死锁和死锁的原因;

5、还问了页锁、乐观锁和悲观锁;

6、乐观锁是如何保证线程安全的?

7、用过线程池吗?对应的好处是什么?如何用?

8、两个10G的文件,里面是一些url,内存只有1G,如何将这两个文件合并,找到相同的url?

9、1000个多并发线程,10台机器,每台机器4核的,设计线程池的大小。

10、代码题:两个有序数组,数组中存在重复数字,合并成一个有序数组,去除重复数字。

11、说一下自己的优缺点;


阿里三面:

1、jvm性能调优都做了什么?

2、数据库性能调优如何做?

3、分布式系统原理:CAP,最终一致性,幂等操作等;

4、高并发情况下,我们系统是如何支撑大量的请求的?

5、集群如何同步会话状态;

6、常用NOSQL,有做过比较?

7、什么情况会出现雪崩,以及如何应对?

8、负载均衡的原理;

9、数据库事务属性;

10、与同事沟通的时候,如果遇到冲突了如何解决?

11、你觉得自己在工作中哪方面欠缺?

12、有问题要问么?

13、你对薪资的期望?

14、为什么要离开现在的公司?

最后

面试经历分享到这里就结束了,以下是一些java面试真题总结分享,适合于java开发1-5年的人,这些资料作者均免费分享,有需要的开发者小伙伴可以自行领取一下。

283页java核心知识点+127页java面试专题手册+2020年最新一线名企面试专题合集大全

领取方式:可以点击此处来获取就可以了!

283页java核心知识点

127页java面试专题手册

一、性能优化面试专栏

二、微服务架构面试专栏

三、并发编程高级面试专栏

四、开源框架面试题专栏

五、分布式面试专栏

5.1、分布式限流面试整理

5.2、分布式通讯面试整理

5.3、分布式数据库面试整理

2020年最新一线名企面试专题合集大全

领取方式:可以点击此处来获取就可以了!

目录
打赏
0
0
0
0
434
分享
相关文章
Java社招面试题:一个线程运行时发生异常会怎样?
大家好,我是小米。今天分享一个经典的 Java 面试题:线程运行时发生异常,程序会怎样处理?此问题考察 Java 线程和异常处理机制的理解。线程发生异常,默认会导致线程终止,但可以通过 try-catch 捕获并处理,避免影响其他线程。未捕获的异常可通过 Thread.UncaughtExceptionHandler 处理。线程池中的异常会被自动处理,不影响任务执行。希望这篇文章能帮助你深入理解 Java 线程异常处理机制,为面试做好准备。如果你觉得有帮助,欢迎收藏、转发!
86 14
Java 面试必问!线程构造方法和静态块的执行线程到底是谁?
大家好,我是小米。今天聊聊Java多线程面试题:线程类的构造方法和静态块是由哪个线程调用的?构造方法由创建线程实例的主线程调用,静态块在类加载时由主线程调用。理解这些细节有助于掌握Java多线程机制。下期再见! 简介: 本文通过一个常见的Java多线程面试题,详细讲解了线程类的构造方法和静态块是由哪个线程调用的。构造方法由创建线程实例的主线程调用,静态块在类加载时由主线程调用。理解这些细节对掌握Java多线程编程至关重要。
53 13
Java 高级面试技巧:yield() 与 sleep() 方法的使用场景和区别
本文详细解析了 Java 中 `Thread` 类的 `yield()` 和 `sleep()` 方法,解释了它们的作用、区别及为什么是静态方法。`yield()` 让当前线程释放 CPU 时间片,给其他同等优先级线程运行机会,但不保证暂停;`sleep()` 则让线程进入休眠状态,指定时间后继续执行。两者都是静态方法,因为它们影响线程调度机制而非单一线程行为。这些知识点在面试中常被提及,掌握它们有助于更好地应对多线程编程问题。
75 9
Java线程调度揭秘:从算法到策略,让你面试稳赢!
在社招面试中,关于线程调度和同步的相关问题常常让人感到棘手。今天,我们将深入解析Java中的线程调度算法、调度策略,探讨线程调度器、时间分片的工作原理,并带你了解常见的线程同步方法。让我们一起破解这些面试难题,提升你的Java并发编程技能!
95 16
Java社招面试中的高频考点:Callable、Future与FutureTask详解
大家好,我是小米。本文主要讲解Java多线程编程中的三个重要概念:Callable、Future和FutureTask。它们在实际开发中帮助我们更灵活、高效地处理多线程任务,尤其适合社招面试场景。通过 Callable 可以定义有返回值且可能抛出异常的任务;Future 用于获取任务结果并提供取消和检查状态的功能;FutureTask 则结合了两者的优势,既可执行任务又可获取结果。掌握这些知识不仅能提升你的编程能力,还能让你在面试中脱颖而出。文中结合实例详细介绍了这三个概念的使用方法及其区别与联系。希望对大家有所帮助!
189 60
Java面试必问!run() 和 start() 方法到底有啥区别?
在多线程编程中,run和 start方法常常让开发者感到困惑。为什么调用 start 才能启动线程,而直接调用 run只是普通方法调用?这篇文章将通过一个简单的例子,详细解析这两者的区别,帮助你在面试中脱颖而出,理解多线程背后的机制和原理。
73 12
Java MyBatis 面试题
Java MyBatis相关基础面试题
Java JVM 面试题
Java JVM(虚拟机)相关基础面试题
Java Dubbo 面试题
Java Dubbo相关基础面试题
Java Druid 面试题
Java Druid 连接池相关基础面试题

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等