并发编程

谈到并发编程,可能很多人都有过经验,甚至比我了解的更多。

那么并发与并行的区别又是什么?

并发编程是编程中的核心问题,实践中,当人们希望利用计算机处理一些现实世界问题,以及希望同时处理多个问题的时候,并发也就出现了。在需要对同一共享资源进行操作,多个事务之间存在关联,人们把这种看起来多个事务同时运行的特性称为并发性。有个经常容易跟并发混肴的概念叫并行,其实真正懂了之后理解并不困难,可以把并行看过是并发实现中某个局部可以引入的运行设施;在讨论并发时,我们一般不需要假设这个运行或者调度设施究竟是怎么实现的,尽管也有一些时候为了效率因素我们会根据这一点来选择恰当的算法或者实现。实现上来看,并发和并行的不同之处,主要在于并发更关注共享或者同步是如何实现的,而并行作为一个局部,注重于如何划分事务,把不相关的部分剥离开来。

可能有的人就会说了:我工作中用不到并发啊?

但事实上面试时并发编程这块还是很重要的,需要大家去捡起这方面的知识来。

这篇文章就主要与大家谈一谈Java领域的并发,以及JAVA并发工具,还与大家谈谈其他领域的并发问题。

大家可以先看一下脑图,让自己脑子里对并发的有一个清晰的认知。

 

看完脑图后如果你还还觉得自己对并发编程原理方面理解一点都不透彻,面试也会有点发怵,那么不妨来看看下面这4份并发编程神仙笔记。(文末还有更多相关资料分享,添加小助理vx:bjmsb2020 即可获取!)

  1. 共享模型篇
  2. 应用篇
  3. 原理篇
  4. 模式篇

共享模型篇

以并发、并行为主线,穿插讲解

 

 

进程与线程

 

Java线程

 

共享模型之管程

 

共享模型之内存

 

共享模型之无锁

 

共享模型之不可变

 

共享模型之工具

 

篇幅限制只能这样简单的展示出来了,需要全部笔记的小伙伴帮忙点赞转发加关注小编支持一下,添加小助理vx:bjmsb2020 即可获取~

应用篇(结合实际)

 

 

原理篇(了然于心)

 

 

 

模式篇(正确姿势)

 

 

 

最后

并发编程乃至一般性编程在技术原理上已经走到了尽头,相关技术也已经在一些语言平台上得到采纳和应用。但出于存在的极个别问题,以及对应用理解的不足,导致在实践中,它们也都还欠缺最后那么一点火候。同时,更多人是依赖平台提供的手段在理解处理问题,而没有从根本上考虑过这些问题,也是应用发展缓慢的一个原因。我们做开发的,首先还是得把底层原理学扎实了才行。这四份笔记也可以让大家查漏补缺。另外还整理了一些额外的相关并发编程资料,以及一些xmind脑图(电脑上刚卸载这个软件,不能给大家展示出来了)。

 

 

篇幅限制为了不影响大家的阅读体验只能以这样的形式展示出来了,需要这些资料的小伙伴,帮忙点赞加关注小编支持一下,然后添加小助理vx:bjmsb2020 即可免费获取!