相信不用我说,大家也都知道掌握并发编程对于一个 Java 程序员的重要性。但相对于其他 Java 基础知识点来说,并发编程更加抽象,涉及到的知识点很多很零散,实际使用也更加麻烦。以至于很多人学完之后,根本不知道自己学了什么。
我在面试的时候,时常会问这个问题:
问:你讲讲线程池的实现原理。
听到这个问题,小部分同学会很坦白的说,我平时用过线程池,但是没有了解过内部是怎么实现的。偶尔也会有同学反怼,我会用不就行了么,为啥要知道咋实现!碰到这样的同学,我只能说,嗯,你说的对。
我希望听到的答案是,把每个参数的作用都说一遍,最好可以在纸上更加直观的描述出来,各个参数在设置的时候需要注意什么问题。
有时候,有些同学语言组织的不太好,描述的时候有点含糊不清,为了能够确定他了解的是否正确,我会直接提供一组线程池参数。
问:比如现在设置coreSize=5,maxSize=10,blockQueueSize=10,依次提交6个比较耗时的任务,线程池是如何执行的?
如果这样还描述不清楚,那真的要pass了。
再给大家举几个简单的问题,大家自测一下,看看如果自己面试中遇到这些问题,能不能回答上来。比如
学习好高并发相关知识,不光是为了能在面试中不被面试官难到,更是为了能满足工作的需求。随着互联网行业的快速发展,高并发已然成为了家常便饭。我们常常被要求开发一个高并发的系统,而掌握并发编程正是其中的关键。
那我们应该怎么学习并发编程呢?是不是一上来就去看Java SDK的并发包?然后死记硬背他们的使用场景?有没有一张“全景图”?
说实话,时至今日也还没有一张普遍认可的“并发编程”全景图,但下面这张图,看到的时候却是让我眼前一亮,是由资深架构师王宝令制成,从三个核心问题:分工、互斥、协作,全面且系统地涵盖了Java并发编程的技术难点。