对于一个 Java 程序员而言,能否熟练掌握并发编程是判断他优秀与否的重要标准之一。因为并发编程是 Java 语言中最为晦涩的知识点,它涉及操作系统、内存、CPU、编程语言等多方面的基础能力,更为考验一个程序员的内功。
所以,并发编程相关的问题经常出现在大厂的面试题里也就不奇怪了。比如说多线程同步和互斥有哪几种实现方法?悲观锁和乐观锁有什么区别?这些面试问题本身都是想考察应聘者的基础能力。同样,随着互联网行业的快速发展,高并发也成为了家常便饭,工作中,你总是绕不开并发编程的任务,比如说,你想写个程序,一边从文件中读取数据,一边还要做实时计算.....
并发编程的优势是可以提高程序的执行效率和资源利用率,短板和难点是它会涉及线程通信、同步互斥等等相关问题。那我们应该怎么学习并发编程呢?是不是一上来就去看 Java SDK 的并发包?然后死记硬背他们的使用场景?
当然不是这样,在我看来,想要学会并发编程,你就需要回到并发的源头思考问题,这样才能举一反三,融会贯通。简单来说,我认为,并发编程领域可以抽象成三个核心问题:分工、同步和互斥,具体如下图。
并发编程全景图
这是我在极客时间《Java 并发编程实战》专栏中的一个总结图片。在这个专栏里,我不想一上来就给你介绍 Java SDK 并发包中的各个工具,相反,我会和你一起挖掘他们背后的设计理念。你知道,这些工具都是并发大师 Doug Lea 设计的,这背后都隐藏着他对并发问题的深刻认识。可惜这个设计的思想目前并没有相关的论文,所以只能自己琢磨了。
扫码购买:
我是谁?
我是王宝令,资深架构师,毕业于东北大学,目前在某大型互联网公司从事电商架构相关的设计工作。我曾主导研发了支持高并发处理能力的 API 网关、高性能数据库连接池以及海量数据归档平台。最近 6 年,我一直从事 Java 开发平台和基础中间件的设计开发工作。
通过《Java 并发编程实战》专栏,我会带你全面系统地搭建起并发编程的知识体系,让你了解问题背后的本质、问题的起源,同时站在理论、模型的角度讲解 Java 并发,让你的知识更加融会贯通。最终让你能够得心应手地解决各种并发难题,同时将这些知识用于其他编程语言,让你的一分辛劳三分收获。
你将获得什么?
1、全面了解并发编程核心原理
我不会死板地“丢”给你一些堆叠的结论,而是把主要精力放在每个概念和理论产生的背景上,将其“串行”起来,挖掘他们背后的关系,带你去发现核心矛盾,找到最终的解决方案。比如,深度认识 Java 内存模型,死锁产生的原因和解决方案,线程间的协作机制等等。
2、深入掌握 12 个 Java 并发工具类,极大提升工作效率
Java SDK 并发包提供了非常丰富的功能,对于初学者来说可谓是眼花缭乱,好多人觉得无从下手。我会探讨 Java SDK 里的 12 个主流并发工具类。首先介绍隐藏在并发包中的管程,以及如何使用。紧接着还会为你详细解读信号量、读写锁、CountDownLatch 和 CyclicBarrier,以及并发编程的三个核心问题——分工、同步、互斥——相关的技术内容。
3、搞懂 9 种最常见的并发设计模式,掌握解决并发问题的关键
并发设计模式是解决并发问题最佳实践的总结,必然是重中之重的内容。其中,最常见的设计模式有 9 种,前 3 种设计模式的核心思想是避免共享变量,从而避免并发问题;后面 6 种设计模式则都属于典型的分工模式。我都会一一详解,让大家搞懂并掌握解决并发问题的关键。
4、 四大经典并发编程实战案例,即学即用
四大实战案例分别是:高性能限流器 Guava RateLimiter、高性能网络应用框架 Netty、高性能队列 Disruptor 和高性能数据库连接池 HiKariCP。我会着重分析 4 个经典的开源框架是如何处理并发问题的,通过这 4 个案例,你会对如何解决并发问题有个更深入的认识。
可以说,跟着我学,从原理到工具再到实战,让你全方位掌握 Java 并发编程,让它成为你进阶加薪的一把利器。换句话说,如果你想进入大厂,你想深入技术,不想一直停留在简单完成增删改查,或者你需要处理秒杀系统 / 用户突增带来的技术问题时,那么,Java 并发编程绝对是一把助力的利剑。
详细目录
扫码购买: