面试整体事项1.简历要准备好,联系方式一定要正确清晰醒目,项目经历按照时间倒序阐述,注意描述自己在项目中承担的职责,简历的模板尽量选择简洁的,毕竟程序员大部分还是喜欢简单明了的。
2.推荐boss直聘,我觉得很好用(不是广告)。
3.一般的整体面试流程都是电面->现场面->HR面->等着。
4.不要觉得HR说让你回去等消息就是GG了,他们也要跟你之前的面试官讨论,再向领导汇报,如果说不急可能还要和其他候选人比较,所以HR让你回去等消息不是说明你完蛋了。
5.面试前准备好自我介绍,1分钟左右就可以,可以写在纸上,电面可以照着念,等你到了现场面了基本也都快背下来你的自我介绍了。
6.准备好扎实的基础,这是一切的根源,没实力怎么都没用的。
7.面试中你可以把你的面试官往你会的知识上引导(我遇到过你会什么他不问什么的)。
8.遇到了设计类题目不要着急,面试官不是为了让你几分钟设计一个高并发高可用设计模式完美的架构,只是想看看你的思路,看看你应变的能力,然后给你些提示看看你能否迅速的调整。
9.offer都会有的,不要着急,把面试当成一个交流的过程。
需要准备的知识以下为在近期面试中比较有印象的问题,也就不分公司了,因为没什么意义,大致分类记录一下,目前只想起这么多,不过一定要知道这些问题只是冰山一角,就算都会了也不能怎么样,最最重要的,还是坚实的基础,清醒的头脑。
Java基础1.HashMap的源码,实现原理,JDK8中对HashMap做了怎样的优化。
2.HaspMap扩容是怎样扩容的,为什么都是2的N次幂的大小。
3.HashMap,HashTable,ConcurrentHashMap的区别。
4.极高并发下HashTable和ConcurrentHashMap哪个性能更好,为什么,如何实现的。
5.HashMap在高并发下如果没有处理线程安全会有怎样的安全隐患,具体表现是什么。
6.java中四种修饰符的限制范围。
7.Object类中的方法。
8.接口和抽象类的区别,注意JDK8的接口可以有实现。
9.动态代理的两种方式,以及区别。
10.Java序列化的方式。
11.传值和传引用的区别,Java是怎么样的,有没有传值引用。
12.一个ArrayList在循环过程中删除,会不会出问题,为什么。
13.@transactional注解在什么情况下会失效,为什么。
数据结构和算法1.B+树
2.快速排序,堆排序,插入排序(其实八大排序算法都应该了解
3.一致性Hash算法,一致性Hash算法的应用
JVM1.JVM的内存结构。
2.JVM方法栈的工作过程,方法栈和本地方法栈有什么区别。
3.JVM的栈中引用如何和堆中的对象产生关联。
4.可以了解一下逃逸分析技术。
5.GC的常见算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。
6.标记清除和标记整理算法的理解以及优缺点。
7.eden survivor区的比例,为什么是这个比例,eden survivor的工作过程。
8.JVM如何判断一个对象是否该被GC,可以视为root的都有哪几种类型。
9.强软弱虚引用的区别以及GC对他们执行怎样的操作。
10.Java是否可以GC直接内存。
11.Java类加载的过程。
12.双亲委派模型的过程以及优势。
13.常用的JVM调优参数。
14.dump文件的分析。
15.Java有没有主动触发GC的方式(没有)。
多线程1.Java实现多线程有哪几种方式。
2.Callable和Future的了解。
3.线程池的参数有哪些,在线程池创建一个线程的过程。
4.volitile关键字的作用,原理。
5.synchronized关键字的用法,优缺点。
6.Lock接口有哪些实现类,使用场景是什么。
7.可重入锁的用处及实现原理,写时复制的过程,读写锁,分段锁(ConcurrentHashMap中的segment)。
8.悲观锁,乐观锁,优缺点,CAS有什么缺陷,该如何解决。
9.ABC三个线程如何保证顺序执行。
10.线程的状态都有哪些。
11.sleep和wait的区别。
12.notify和notifyall的区别。
13.ThreadLocal的了解,实现原理。
数据库相关常见的数据库优化手段 索引的优缺点,什么字段上建立索引 数据库连接池。
durid的常用配置。
计算机网络TCP,UDP区别。
三次握手,四次挥手,为什么要四次挥手。
长连接和短连接。 连接池适合长连接还是短连接。
设计模式