跟着作者的65节课彻底搞懂Java并发原理专栏,一步步彻底搞懂Java并发原理。
作者简介:笔名seaboat,擅长工程算法、人工智能算法、自然语言处理、计算机视觉、架构、分布式、高并发、大数据和搜索引擎等方面的技术,大多数编程语言都会使用,但更擅长Java、Python和C++。平时喜欢看书写作、运动、画画。崇尚技术自由,崇尚思想自由。出版书籍:《Tomcat内核设计剖析》、《图解数据结构与算法》、《图解Java并发原理》、《人工智能原理科普》。
多线程引出的问题
我们都知道多线程机制能减少任务执行时间和提供并发处理能力,同时我们也知道天下没有免费的午餐,多线程机制也是需要付出代价的,它也引入了很多问题需要我们去解决,其中主要包含三个问题。
- 数据竞争、竞争条件问题,前者与多线并发修改内存数据相关,而后者则是并发执行导致运行结果不可预估。本篇文章将对这两个问题进行深入分析。
- 不同级别存储的数据一致性问题,主要是现代计算机的CPU为了提高执行速度而引入了不同访问速度的存储介质,比如磁盘->主存->缓冲->寄存器结构,对于共享变量,每个线程都会有自己的副本,随着并发的进行就可能会产生一致性问题。
- 编译器及CPU的优化,编译