美文网首页
01 并发概述

01 并发概述

作者: MineCoinChain | 来源:发表于2019-05-24 17:18 被阅读0次

什么是并发

我们先来举一个很常见的例子:

如果你现在很渴想泡壶茶喝,但你发现家里没有茶叶,水杯都放了很久没洗,并且没有开水,这时候你会怎么做呢?

Method A:

先出去买茶叶,然后回来把水杯洗了,再然后烧水,最后就可以开心的泡茶了。

Method B:

先把水烧上,在烧水的间隙出去买茶叶,回来后洗茶杯,等水烧好就可以开心的泡茶了。

在这里如果我们假设:买茶叶需要3分钟,洗水杯需要4分钟,烧水需要15分钟。我们可以看到:

Method A总共需要花费:3+4+15=22分钟

Method B总共需要花费:15分钟

OK 到这里我想你大概明白我在讲什么了。很明显,Method A中我们在面对买茶叶、洗茶杯、烧水这三个任务的时候,我们每次只执行一个任务,当前任务没有结束的情况下,我们不执行下一个任务,我们把这种方式叫做串行

但是烧水这个任务有很长的等待时间,在这个等待时间里我们完全可以执行其它任务,所有我们有了method B这种方案。在当前任务没有执行完的情况下,我们可以执行下一个任务,达到多个任务同时执行的效果,我们把这种方式叫做并发

通过上面的例子我们可以看到并发在多任务下的一个优点:在当前任务陷入阻塞或等待的情况下,有效利用当前计算资源。

并发和并行

并发和并行都是处理多任务的方式,从宏观角度来看,并发和并行的执行效果没有任何区别,但是从微观角度来讲,两者差距很大。

也许此时此刻你正坐在电脑前听着音乐看这篇博客,同时你的360也在后台为你运行电脑的健康监测。我们定义任务A为浏览网页博客,任务B为听音乐,任务C为后台检测电脑状态。

如果你的电脑是单核的,那么从微观角度来看,他的任务执行是这个样子的。

如果你的电脑是多核的,那么从微观角度来看,他们的任务执行顺序是这个样子的。

如果你的电脑是单核的,那么在一个CPU上A、B、C三个任务需要轮流执行,在具体的某一个时刻只有一个任务在执行。只不过因为CPU的切换速度很快,所以你看到的效果就是他们是同时运行的。但对于多核的电脑来说,ABC三个任务完全可以在不同的CPU上来执行,每个CPU只执行一个任务,他们之间互不影响。

如果你觉得这个例子还是难以理解,可以看看国外大咖提出的买咖啡的例子:

对于并发来说,只有一个咖啡机,所以两个队列需要交替使用一台咖啡机。

对于并行来说,有两个咖啡机,两个队列各买各的,互不影响。

相信你已经看出来了,对于并行没有什么可研究的,只需要电脑硬件支持就可以了,下面我们就来详细谈谈并发。

相关文章

  • 01 并发概述

    什么是并发 我们先来举一个很常见的例子: 如果你现在很渴想泡壶茶喝,但你发现家里没有茶叶,水杯都放了很久没洗,并且...

  • 01-并发概述

    并发编程由来: 串行与并行 并发编程目的 并发编程的场景

  • MySQL数据库锁机制

    01概述 数据库事务ACID中的隔离性是通过锁和MVCC实现的,锁用于并发写操作,MVCC用于并发读操作。因此,数...

  • Java并发教程

    Java并发教程 Java并发概述Java并发环境设置Java并发主要操作Java并发性线程间通信Java并发同步...

  • Java并发之三:并发概述

    线程安全是一个比较复杂的概念。当多个线程访问某个类时,不受运行环境的调度方式和这些线程的交替执行顺序的影响,也不需...

  • 带你读 ConcurrentHashMap 1.7 1.8

    概述: ConcurrentHashmap是java并发中重要的类,用来替代HashTable,实现可并发的has...

  • 转-Java并发之AQS详解

    Java并发之AQS详解 一、概述 谈到并发,不得不谈ReentrantLock;而谈到ReentrantLock...

  • 高并发架构设计

    01 概述 高并发(High Concurrency)是互联网分布式系统架构设计中必须考虑的因素之一,它通常是指,...

  • Java并发包-概述

    天下武功无坚不摧,唯快不破,性能在大型软件应用架构的核心要素中占有一席之地。最近拜读了《多线程编程实战》及《深入理...

  • Java并发-框架概述

    前面几篇文章介绍了java.util包下的集合List和Map,从这篇文章开始介绍java.util.concur...

网友评论

      本文标题:01 并发概述

      本文链接:https://www.haomeiwen.com/subject/qpzwzqtx.html