【高并发】学好并发编程,需要掌握这些核心知识体系!!

简介: 很多小伙伴问我:我在大学时候就学习了多线程,工作后,自己也看过不少有关多线程和并发编程的书籍和视频,为啥真正到工作的时候,我还是不知道在项目中哪里会用到并发编程。我知道有关于并发编程的各个知识点,但是没办法将这些知识点串起来,形成知识体系。冰河,你能不能推一篇文章,讲讲如何学习并发编程,如何将并发编程的各个知识点串成知识体系呢?今天,我们就一起来探讨下有关于并发编程的核心知识体系。

并发编程的核心

我们先来看下并发编程的三大核心知识图。

微信图片_20211119172858.jpg

核心问题

要想学好并发编程,首先要理解三个核心的问题:分工,同步和协作(《【高并发】要想学好并发编程,关键是要理解这三个核心问题》)。

诡异的问题

并发编程并不像普通业务中的CRUD那么简单,往往在并发编程中会出现各种各样诡异的Bug问题(《【高并发】导致并发编程频繁出问题的“幕后黑手”》),而且这些问题也不好复现。究其根本原因,是操作系统的CPU与内存和I/O存在速度差异,而操作系统和编译器在解决这些速度差异带来的问题时,又引入了可见性(《【高并发】解密导致诡异并发问题的第一个幕后黑手——可见性问题》)、原子性(《【高并发】解密导致并发问题的第二个幕后黑手——原子性问题》)、有序性(《【高并发】解密导致并发问题的第三个幕后黑手——有序性问题》)问题,而这三个核心问题,就是导致并发编程出现各种诡异Bug的根本所在。

如何解决问题

在Java中,如何解决并发编程中的可见性、原子性和有序性问题呢?在Java中提供了内存模型和互斥锁的方案来解决这些问题。在Java的内存模型中,有一个很重要的原则,那就是:Happens-Before原则(《何为Happens-Before原则?这次彻底懂了!》)。通过Java的内存模型,能够解决可见性和有序性问题(《【高并发】如何解决可见性和有序性问题?这次彻底懂了!》),对于如何解决原子性问题,我们使用的是互斥锁方案(《【高并发】如何使用互斥锁解决多线程的原子性问题?这次终于明白了!》)。

互斥锁带来的问题

互斥锁在是解决并发问题的核心方案,但是一不留神就会引起死锁(《【高并发】高并发环境下诡异的加锁问题(你加的锁未必安全)》、《【高并发】优化加锁方式时竟然死锁了!!》)

优化加锁方式

既然互斥锁会带来死锁的问题,那我们如何优化加锁的方式呢?(《【高并发】高并发场景下如何优化加锁方式?看完这篇我确实明白了!!》)

线程知识

线程的生命周期(《【高并发】线程的生命周期其实没有我们想象的那么简单!!》)、高并发场景下我们到底创建多少线程合适(《【高并发】高并发场景下创建多少线程才合适?一条公式帮你搞定!!》)?为什么局部变量就是线程安全的(《【高并发】终于弄懂为什么局部变量是线程安全的了!!》)?为什么很多小伙伴面试会栽在InterruptedException上(《【高并发】由InterruptedException异常引发的思考》)?我可以用Java中的面向对象的思想写好并发程序,你信吗(《【高并发】信不信?以面向对象的思想是可以写好高并发程序的!》)?

核心案例

秒杀系统架构解密(《【高并发】高并发秒杀系统架构解密,不是所有的秒杀都是秒杀!》)

分布式锁架构解密(《【高并发】高并发分布式锁架构解密,不是所有的锁都是分布式锁!!》)

分布式限流理论(《【高并发】如何实现亿级流量下的分布式限流?这些理论你必须掌握!!》)

分布式限流算法(《【高并发】如何实现亿级流量下的分布式限流?这些算法你必须掌握!!》)

实现HTTP接口限流(《【高并发】亿级流量场景下如何为HTTP接口限流?看完我懂了!!》)

实现分布式限流(《【高并发】亿级流量场景下如何实现分布式限流?看完我彻底懂了!!》)

更多内容

有关更多并发编程的知识,小伙伴们可以到【高并发专题】进行系统学习。

好了,今天就到这儿吧,我是冰河,我们下期见!

相关文章
|
7月前
|
并行计算 Go 数据处理
掌握Go语言:Go 并发编程,轻松应对大规模任务处理和高并发请求(34)
掌握Go语言:Go 并发编程,轻松应对大规模任务处理和高并发请求(34)
|
缓存 负载均衡 算法
我佛了!Java开发者福音:并发编程源码剖析+高并发系统搭建
多线程和高并发的关系和区别 “高并发和多线程”总是被人一起提起,给人感觉两者好像相等,实则 高并发 ≠ 多线程 多线程 多线程是Java的特性,因为现在cpu都是多核多线程的,可以同时执行几个任务,为了提高jvm的执行效率,Java提供了这种多线程的机制,以增强数据处理效率。多线程对应的是cpu,高并发对应的是访问请求,可以用单线程处理所有访问请求,也可以用多线程同时处理访问请求。
|
缓存 监控 网络协议
并发编程-26 高并发处理手段之服务降级与服务熔断 + 数据库切库分库分表
并发编程-26 高并发处理手段之服务降级与服务熔断 + 数据库切库分库分表
113 0
|
消息中间件 算法 Dubbo
并发编程-25 高并发处理手段之消息队列思路 + 应用拆分思路 + 应用限流思路
并发编程-25 高并发处理手段之消息队列思路 + 应用拆分思路 + 应用限流思路
124 0
|
缓存 NoSQL Redis
并发编程-24 高并发处理手段之扩容思路 + 缓存思路
并发编程-24 高并发处理手段之扩容思路 + 缓存思路
107 0
|
Java
【高并发】InterruptedException异常会对并发编程产生哪些影响?
当我们在调用Java对象的wait()方法或者线程的sleep()方法时,需要捕获并处理InterruptedException异常。如果我们对InterruptedException异常处理不当,则会发生我们意想不到的后果!
201 0
【高并发】InterruptedException异常会对并发编程产生哪些影响?
|
消息中间件 缓存 安全
一起来认识Java 并发编程与高并发
一起来认识Java 并发编程与高并发
|
存储 设计模式 Java
【高并发】并发编程到底应该学什么?一张图秒懂!!
在【高并发专题】中,我陆续发表了一些高并发编程的知识,同时,也将高并发编程的文章整理成了一部392页共36W字的超硬核PDF文档——《深入理解高并发编程(第1版)》,目前,这份文档是全网最牛的开源免费的高并发编程PDF,累计下载量突破6W+。 很多读者留言说,不知道并发编程究竟应该学习什么。其实,学习技术需要掌握其原理和精髓,所谓万变不离其宗,只要我们掌握了最基本的原理,任凭其上层的应用和框架如何变化,我们都能够迅速掌握!! 并发编程学什么?
272 0
【高并发】并发编程到底应该学什么?一张图秒懂!!
|
存储 缓存
【高并发】导致并发编程频繁出问题的“幕后黑手”
工作了3年的小菜同学,平时在公司只是做些CRUD的常规工作,这次,出去面试被面试官一顿虐啊!尤其是并发编程的知识简直就是被吊打啊。小菜心有不甘,回来找自己工作经验非常丰富的朋友大冰来帮助自己提升并发编程的知识,于是便有了接下来的一系列小菜学并发的文章。
123 0
【高并发】导致并发编程频繁出问题的“幕后黑手”
|
安全 前端开发 Java
【高并发】要想学好并发编程,关键是要理解这三个核心问题
写【高并发专题】有一段时间了,一些读者朋友留言说,并发编程很难,学习了很多的知识,但是在实际工作中却无从下手。对于一个线上产生的并发问题,又不知产生这个问题的原因究竟是什么。对于并发编程,感觉上似乎是掌握了,但是真正用起来却不是那么回事!
129 0
【高并发】要想学好并发编程,关键是要理解这三个核心问题

热门文章

最新文章

  • 1
    Nginx实现高并发
    91
  • 2
    高并发场景下,到底先更新缓存还是先更新数据库?
    96
  • 3
    Java面试题:解释Java NIO与BIO的区别,以及NIO的优势和应用场景。如何在高并发应用中实现NIO?
    98
  • 4
    Java面试题:设计一个线程安全的单例模式,并解释其内存占用和垃圾回收机制;使用生产者消费者模式实现一个并发安全的队列;设计一个支持高并发的分布式锁
    83
  • 5
    Java面试题:如何实现一个线程安全的单例模式,并确保其在高并发环境下的内存管理效率?如何使用CyclicBarrier来实现一个多阶段的数据处理任务,确保所有阶段的数据一致性?
    83
  • 6
    Java面试题:结合建造者模式与内存优化,设计一个可扩展的高性能对象创建框架?利用多线程工具类与并发框架,实现一个高并发的分布式任务调度系统?设计一个高性能的实时事件通知系统
    70
  • 7
    Java面试题:假设你正在开发一个Java后端服务,该服务需要处理高并发的用户请求,并且对内存使用效率有严格的要求,在多线程环境下,如何确保共享资源的线程安全?
    87
  • 8
    在Java中实现高并发的数据访问控制
    55
  • 9
    使用Java构建一个高并发的网络服务
    40
  • 10
    微服务06----Eureka注册中心,微服务的两大服务,订单服务和用户服务,订单服务需要远程调用我们的用,户服务,消费者,如果环境改变,硬编码问题就会随之产生,为了应对高并发,我们可能会部署成一个集
    61