要了解多线程,我们先来了解几个简单的概念

每当面试官问我们线程,进程分别什么,80%童鞋都会回答:进程是资源分配的最小单位,线程是CPU调度的最小单位?但是这样的回答感觉太抽象,都不太容易让人理解。

做个简单的比喻: 进程(火车),线程(车厢),当然类比工厂和车间也是可以的

1、线程在进程下行进(单纯的车厢无法运行)

2、一个进程可以包含多个线程(一辆火车可以有多节车厢)

3、不同进程间数据是很难共享的(一辆火车上的乘客很难换到另外一辆火车,比如站点换乘)

4、同一进程下不同线程间数据很容易共享(A车厢换到B车厢很容易)

5、进程要比线程消耗更多的计算机资源(采用多列火车相比多个车厢更耗资源)

6、进程间不会相互影响,一个线程挂掉将导致整个进程挂掉(一辆火车不会影响到另外一列火车,但是如果一列火车上中间的一节车厢着火,将影响到所有车厢)

7、进程可以拓展到多机器,进程最多适合多核(不同火车可以开在多个轨道上,同一火车的车厢不能在行进的不同轨道上)

8、进程使用的内存地址可以上锁,即一个线程使用某些共享内存时,其他线程必须等它结束,才能使用这一块内存(比如火车上的洗手间) --“互斥锁”

9、进程使用的内存地址可以限定使用量(比如火车上的餐厅,最多只允许多少人进入,如果满了需要在门口等待,等有人出来了才能进去) --“”信号量

今天小编分享一位骨灰级扫地神僧出版的《多线程与高并发》,这两大块儿是现在面试问得越来越多,也是相对一个初级的程序员向中高级迈进的必须要踏过的一个坎儿。本书籍带你将多线程的知识系统化,帮助你理解多线程在CPU层级的实现,以及这些实现如何一层一层地映射到那些上亿用户,千万QPS,百万TPS的系统

横扫一切关于多线程的问题,吊打所有敢于提问并发问题的面试官。(面试官大佬别放心上哈)

《多线程与高并发》共由九节组成

第一节:线程的基本概念

 

第二节:volatile与CAS

 

第三节:Atomic类和线程同步新机制

 

第四节:LockSupport、淘宝面试题与源码阅读方法论

 

第五节:AQS源码阅读与强软弱虚4种引用以及ThreadLocal原理与源码

 

第六节:并发容器

 

第七节:线程池

 

第八节:线程池与源码阅读

 

第九节:JMH与Disrupor

 

《多线程与高并发》电子版

 

需要获取完整电子版书籍以及实体书籍的朋友们关注我后转发此文,添加VX:“MXM9809”免费领取。(记得转发分享哦,感谢!!)