当前位置: 主页 > JAVA语言

java初-JavaCore多线程,异常处理流程以及JVM虚拟机优化

发布时间:2023-07-12 10:02   浏览次数:次   作者:佚名

如果你要应聘高级开发,那在上述基础上,最好了解如下的知识点:

4

数据库方面需要准备的点

不少候选人会看很多SQL的技巧,比如select该怎么写,insert又该怎么写,但仅限于此,不会再准备其它的。

这样就很吃亏,因为面试官会认为,哪怕是初级开发,SQL语句也该会写,所以这块不会多问,而会问如下方面的问题。

1. 索引怎么建的,怎么用的?比如我建好了一个索引,在where 语句里写 name like '123%'会不会走索引java初,怎么情况下不该建索引,哪些语句不会走索引。

2. 除了索引之外,你有过哪些SQL优化方面的经验,比如分库分表,或通过执行计划查看SQL的优化点。这最好是能结合你做的项目实际来讲。

这里,我面试下来,大概有70%的候选人只知道基本SQL的写法,所以哪怕你是只有理论经验,会说一些优化点,也是非常有利的。

这块对于高级开发而言,更得了解优化方面的技能。

5

java初

Java Core方面需要准备的点

这块是基础,其实很多问的问题,候选人一定会在项目里用到,但很少能说好说全。这块主要会从集合,多线程,异常处理流程以及JVM虚拟机这些方面来问。

● 集合方面:

1. hashcode有没有重写过?在什么场景下需要重写。如果可以,结合hash表的算法,说下hashmap的实现原理。

对于高级开发而言,最好通过ConcurrentHashMap来说明下并发方面的底层实现代码。

2. ArrayList,LinkedList的差别,比如一个基于数组,一个基于链表,它们均是线程不安全的,ArrayList的扩容做法等。

对于高级而言,最好看下底层的代码。

3. Set如何实现防重的,比如TreeSet和HashSet等。

4. Collection的一些方法,比如比较方法,包装成线程安全的方法等。

java初

5. 可能有些面试官会问,如何通过ArrayList实现队列或堆栈,这个可以准备下。

●多线程方面,其实在项目里不怎么会用到,但会问如下的问题:

1. synchronized和可重入锁的差别,然后可能会顺便问下信号量等防并发的机制。

2. 在线程里该如何返回值,其实就是callable runnable 区别。

3. 一定得通过ThreadLocal或volatile关键字,来说明线程的内存模型。

4. 线程池方面,会用,了解些常用参数

线程方面,可能问得比较多的就是并发机制,如果是高级开发,可能会问得深些。

●虚拟机方面:

1. 结构图和流程可以大致说下。

java初

2. 一定得了解针对堆的垃圾回收机制,具体而言,可以画个图,说下年轻代年老代等。

3. 说下垃圾回收的流程,然后针对性地说下如何在代码中优化内存性能。

4. 最好说下如果出现了OOM异常,该怎么排查?如何看Dump文件。

5. GC的一些概念,比如强弱软引用,finalize方法等,这些可以准备下。

6

算法,设计模式等,其实是虚的

这块好准备java初,不过话说哪怕这些没回答好,但能证明有相关技能的项目经验,一般也会让过。

不过在这块,不少候选人就本末倒置了,比如就准备算法,设计模式,刚才提到的框架,数据库和Java Core方面就不准备了。这样很吃亏,就好比考政治只复习了一个点,其它一点也不准备。

7

java初

哪类回答就能证明候选人比较资深

1. 大多数的候选人(大概7成)直接就来了,不做任何准备。要知道,面试和项目其实有些脱节,哪怕项目做得再好,不做准备照样通不过,只要我确认过这类人确实无法达标,我拒掉他们没任何心理负担,谁让他们不准备?

2. 还有些候选人态度很好,明显准备过,但没准备到位,比如像刚才所说,只准备了算法,或者在Java Core方面,只看了集合方面的面试题。对于这些同学,哪怕是过了,我也会感到惋惜,毕竟如果面试好些的话,工资也能更高些,至于哪些过不了的,我敢说,如果他们准备过,估计就不是这个结果了。

其实我也知道,人无完人,哪怕我自己去面试,也不可能面面俱到,所以,我不会要求候选人什么问题都能回答出,甚至大多答错也没关系,只要能证明自己的能力即可通过面试。

我也和不少面试官交流过,根据我们的经验,如果候选人能说出如下的知识点,即能证明他在这个领域比较资深了,在这块,我可能就不会过多地问问题了。

架构方面

1. 能证明自己可以干活(这不难),同时能结合底层代码说出IOC,AOP或Spring MVC的流程,只要能说出一个即可。或者能说出拦截器,Controller等的高级用法。

2. 能证明自己有Spring Boot或Spring Cloud的经验,比如能说出些Spring Cloud组件的用法。

3. 如果能证明自己有分布式开发的经验,那最好了,其实这不难证明,比如能说出服务的包是放在多台机器上(大多数公司其实都这样),而且能说出如何部署,如何通过nginx等做到负载均衡。

java初

数据库方面,其实讲清楚一个问题即可:如何进行SQL调优,比如通过索引,看执行计划即可,如果有其它的优化点,说清楚即可。

Java Core方面,这里给出些诀窍:

1. 能结合ConcurrentHashMap的源代码,说出final,volatile,transient的用法,以及在其中如何用Lock对象防止写并发。

2. 结合一个项目实际,说下设计模式的实践。

3. 多线程方面,能说出Lock或volatile等高级知识点的用法。

4. 这块最取巧:说下GC的流程,以及如何通过日志和Dump文件排查OOM异常,如果再高级些的话,说下如何在代码中优化内存代码。

诀窍点归结成一个:能结合源代码或项目实际,说出些比较资深的问题。

面试一定得准备 (重要的话说三遍,这里已经超过3遍了)

java初

java初