前言
上个月4号通过阿里工作的学长进行内推,7天简历评估,11号接到电话面试,尽管猝不及防回答仓促,但好在前期准备充分,通过。3天后进行现场面试,通知时间为早上10点。当日设了七点闹钟,结果五点五十三分惊醒后再无法入睡,起床,重新翻看之前做的笔记和重点,在lintcode上找了几道可能性较大的题进行练手。10点准时在蚂蚁金服总部开始面试,十点四十七分结束。15号收到通知,现场面通过,16号进行HR面,22号收到Offer。
面试内容如下:
01 JAVA基础
1.1 java知识点
- Hashmap 源码级掌握,扩容,红黑树,最小树化容量,hash冲突解决,有些面试官会提出发自灵魂的审问,比如为什么是红黑树,别的树不可以吗;为什么8的时候树化,4不可以吗,等等
- concureentHashMap,段锁,如何分段,和hashmap在hash上的区别,性能,等等
- HashTable ,同步锁,这块可能会问你synchronized关键字 1.6之后提升了什么,怎么提升的这些
- ArrayList 优势,扩容,什么时候用
- LinkedList 优势,什么时候用,和arraylist的区别 等等
- 基本类型和包装类型的区别,涉及自动装箱和拆箱,怎么做的,原理
- String ,StringBuffer,StringBuilder哪个是安全的
- 字符串编码的区别,被问到过,我觉得比较容易被忽视的一个点
- 什么是泛型,怎么用泛型
- static能不能修饰threadLocal,为什么,这道题我当时一听到其实挺懵逼的
- Comparable和Comparator接口是干什么的,其区别
- 多态的原理是什么,感觉这个很容易被问到
- 接口和抽象类,面试官问我是怎么理解的,我说接口对应功能,抽象类对应属性,然后面试官给我说了他的看法,说抽象类更偏向于一种模板~ 然后又交流了一下各自的想法
- 如何通过反射和设置对象私有字段的值
- 快速失败(fail-fast)和安全失败(fail-safe)的区别是什么
- synchronized 的实现原理以及锁优化?
- volatile 的实现原理?
- Java 的信号灯?
- synchronized 在静态方法和普通方法的区别?
- 怎么实现所有线程在等待某个事件的发生才会去执行?
- CAS?CAS 有什么缺陷,如何解决?
- synchronized 和 lock 有什么区别?
- Hashtable 是怎么加锁的 ?
- List,Map,Set接口在取元素师,各有什么特点
- 如何线程安全的实现一个计数器
- 生产者消费者模式,要求手写过代码,还是要知道的
- 单例模式,饿汉式,懒汉式,线程安全的做法,两次判断instance是否为空,每次判断的作用是什么。
- 线程池,这个还是很重要的,在生产中用的挺多,四个线程池类型,其参数,参数的理解很重要,corepoolSize怎么设置,maxpoolsize怎么设置,keep-alive各种的,和美团面试官探讨过阻塞队列在生产中的设置,他说他一般设置为0,防止用户阻塞
- cyclicbarrier 和countdownlatch的区别