知识点学习法----连环炮

本文针对Java程序员面试提供了详细的准备指南,覆盖数据结构、并发编程、I/O操作及JVM内部机制等多个方面,通过连环炮式的提问方式帮助读者深入理解Java核心技术。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:点击打开链接http://www.cnblogs.com/zuoxiaolong/p/life51.html#3936308

这种连环炮提问,倒是学习某个知识点的好方法

LZ会分为四个部分来谈论这个问题,由于LZ本身是Java出身,因此关于主语言的问题,都是与Java相关,其它语言的同学可以选择性忽略。此外,面试的时候一般面试官的问题都是环环相扣,逐渐深入的,这点在下面大家可以更明显的感受出来。

 

  1、主语言本身以及它的高级特性。

  主语言当然就是你平日里拿来赚钱的家伙。不要告诉LZ你没有主语言,你会N多种语言,或者是你精通N多种语言,你要非这么说的话,你可以来杭州试试,LZ保证不打死你,最多打残。

  LZ的主语言很显然是Java,那么对于Java来说,它的语言本身以及它的高级特性,都有哪些比较容易在面试中问到呢?

  一般情况下,主要有以下知识点很容易被问到。(PS:以下所列举的,都是一些Java相对而言比较高级一点的知识点,因为这里谈的是社招,而不是校招)

  1)Java的数据结构相关的类实现原理,比如LinkedList,ArrayList,HashMap,TreeMap这一类的。以下简单模拟一个数据结构的连环炮。

  比如,面试官先问你HashMap是不是有序的?

  你肯定回答说,不是有序的。那面试官就会继续问你,有没有有顺序的Map实现类?

  你如果这个时候说不知道的话,那这个问题就到此结束了。如果你说有TreeMap和LinkedHashMap。

  那么面试官接下来就可能会问你,TreeMap和LinkedHashMap是如何保证它的顺序的?

  如果你回答不上来,那么到此为止。如果你依然回答上来了,那么面试官还会继续问你,你觉得它们两个哪个的有序实现比较好?

  如果你依然可以回答的话,那么面试官会继续问你,你觉得还有没有比它更好或者更高效的实现方式?

  如果你还能说出来的话,那么就你所说的实现方式肯定依然可以问你很多问题。

  以上就是一个面试官一步一步提问的例子。所以,如果你了解的不多,千万不要敷衍,因为可能下一个问题你就暴露了,还不如直接说不会,把这个问题结束掉,赶紧切换到你熟悉的领域。

 

  2)Java并发包当中的类,它们都有哪些作用,以及它们的实现原理,这些类就是java.concurrent包下面的。与上面一样,咱们也简单的模拟一个并发包的连环炮。

  比如面试官可能会先问你,如果想实现所有的线程一起等待某个事件的发生,当某个事件发生时,所有线程一起开始往下执行的话,有什么好的办法吗?

  这个时候你可能会说可以用栅栏(Java的并发包中的CyclicBarrier),那么面试官就会继续问你,你知道它的实现原理吗?

  如果你继续回答的话,面试官可能会继续问你,你还知道其它的实现方式吗?

  如果你还能说出很多种实现方式的话,那么继续问你,你觉得这些方式里哪个方式更好?

  如果你说出来某一个方式比较好的话,面试官依然可以继续问你,那如果让你来写的话,你觉得还有比它更好的实现方式吗?

  如果你这个时候依然可以说出来你自己更好的实现方式,那么面试官肯定还会揪着这个继续问你。

  为什么说面试的时候要引导面试官,原因就在这了。因为面试官的提问很多时候都是有迹可循的,你如果抓住了他的轨迹,能够猜到他下面很可能会问什么,那你在回答的时候就可以往你想要谈的方向去说。这样面试时就会显得更加从容,更加的游刃有余。

  

  3)IO包和NIO包中的内容。这部分里面NIO会是重点,IO包大部分都会比较熟悉,因此可能会直接略过,直接问你NIO的内容。

  IO包和NIO包的内容相对来说不是很多,首先NIO模型要熟悉,特别是其中的selector一定要非常清楚它的职责和实现原理。其实NIO的核心是IO线程池,一定要记住这个关键点。有的时候,面试官可能也会问你IO包的设计模式(装饰器模式),为什么要这样设计?

  有的面试官还会问你有没有更好的设计,这个时候如果你不知道请果断说自己现在的水平有限,想不出来更好的设计,千万不要信口开河,随意YY。

  

  4)Java的虚拟机的内容。这部分主要包括三部分,GC、类加载机制,以及内存。

  一个GC部分简单的连环炮。

  面试官可以先问你什么时候一个对象会被GC?

  接着继续问你为什么要在这种时候对象才会被GC?

  接着继续问你GC策略都有哪些分类?

  你如果说出来了,继续问你这些策略分别都有什么优劣势?都适用于什么场景?

  你继续说出来了以后,给你举个实际的场景,让你选择一个GC策略?

  你如果选出来了,继续问你,为什么要选择这个策略?

  下面是关于类加载机制的简单连环炮。

  首先肯定是先问你Java的类加载器都有哪些?

  回答了这些以后,可能会问你每个类加载器都加载哪些类?

  说完以后,可能会问你这些类加载之间的父子关系是怎样的?

  你在回答的时候可能会提到双亲委派模型,那么可以继续问你什么是双亲委派模型?

  你解释完了以后,可能会继续问你,为什么Java的类加载器要使用双亲委派模型?

  你回答完以后,可能会继续问你如何自定义自己的类加载器,自己的类加载器和Java自带的类加载器关系如何处理?

  再来一个关于内存的连环炮。

  首先肯定就是问你内存分为哪几部分,这些部分分别都存储哪些数据?

  然后继续问你一个对象从创建到销毁都是怎么在这些部分里存活和转移的?

  接着可能会问你,内存的哪些部分会参与GC的回收?

  完事以后,可能还会问你Java的内存模型是怎么设计的?

  你回答了以后,还会继续问你为什么要这么设计?

  问完以后,还可能会让你结合内存模型的设计谈谈volatile关键字的作用?

  你在谈的时候,肯定会提到可见性,那么接着可见性这三个字,还可以继续问你并发的内容。

  

  基本上Java语言本身以及语言稍微高级点的内容就是以上部分,如果你能把以上四部分了解的非常透彻,那基本上Java这部分就没啥问题了,因为光以上的内容就够你跟面试官聊很久了。你聊这些聊得久了,自然问你其它问题的时间就会短点。

  你从LZ写这些问题的过程也应该能感受出来,很多时候,面试官都是顺着一条线一路问下去的,如果你觉得这条线你不熟悉的话,就要及时拐弯,引导面试官去问其它方面的问题。千万不要一直往下深入,直到自己跳不出来为止,那就尴了个尬了。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值