示例说明多线程的两组概念:串行VS并行 和 并发VS顺发

2023-11-24 19:20

本文主要是介绍示例说明多线程的两组概念:串行VS并行 和 并发VS顺发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

顺发(Sequential)、并发(Concurrent)、串行(Serial)和并行(Parallel)都是多线程任务中的重要概念。由于多线程的复杂性,所以需要使用者有对这些概念有清晰尝试的认识。然而目前网上大量的文章描述的解释大多不是很清楚,甚至还有一些的解释或示例是错误的。因此,本文就这几个概述概念通过具体的实例进行解释。

顺发VS并发

顺发 (Sequential)

小李要参加一个会议,于是出门前先洗澡打扮,再开车到现场,参加了这个会议。我们发现有这几件事是顺序进行的:

洗澡 --> 打扮 --> 开车 --> 参会

这个过程有以下特点:

  1. 每件事情是按时间顺序发生;
  2. 任何两件事情都是独立的;
  3. 所有的事情均由同一个人完成。

所以,顺发的概念在多任务处理中,对应的就是1个处理器的核心,按顺序一件一件处理任务,即在任务执行时,只有当前任务完成才会开始下个任务

顺便,再以这个示例说一下并行:就在小李准备开会的过程中,会议的相关人员实际上已经开始工作了,比如:

小李:洗澡 --> 打扮 --> 开车 --> 参会 
主持人:准备会议进程 --> 主持会议
工作人员A:部署现场 --> 配合会议 --> 收拾会场
报告人:准备PPT --> 做报告 --> 问讨论

这个过程有以下特点:

  • 每个人都在顺发地执行自己的任务。
  • 任意两人都是完全同时可以做各自的任务。

所以,并行的概述也很清楚,即处理器的多个核心,同时独立地各自完成不同的任务。

并发 (Concurrent)

我们再举三个例:洗澡,来电话,吃东西,对于这三件事。A和B两人有不同的方式:
A:先洗澡,再打电话,最后吃东西
B:边洗澡,边打电话,边吃东西。

A就是顺发,即每件任务都是顺序发生,在一个任务没完成前,不开始另一个任务。这样在处理任务时就会发生阻塞,即另一任务的开始需要等等当前任务的结束。

而B则是并发方式,即可以在当前任务进行中时,随时切换到另一任务,如在吃东西的时候不能说话,但是吃完一口后,就切换到打电话的任务中,从而保证电话任务的正常运行;而在听电话,不吃东西的时候,又可以洗澡。总之,并发是多件任务看上去是同时在进行,实际上仍然是单个处理器在处理,只不过可以在多个任务中不断切换,从而能够有效避免阻塞。

由于任务切换是耗时的操作,所以在总任务量不变的情况下,并发的速度肯定没有顺发快。不过现代计算机发展非常快,任务切换的耗损已经基本可以忽略不计,所以并发的性能与顺发基本相同。所以两个任务顺序执行的话,先开始的任务一定会比后开始的先完成,而并发执行则不一定。

再附一张Erlang 之父 Joe Armstrong画的一张并发与并行原理示意图。
在这里插入图片描述

串行VS并行

一个项目的实现过程,基本就包括了串行和并行的内容。

串行 (Serial)

一个项目通常需要 设计、开发、测试和上线几个步骤,这几个过程肯定是串行的,即:

开始--->设计(10人天) --> 开发(200人天) --> 测试(20人天) -->结束

这三个过程是串行的,即如字面意思一样,可以串成一串来执行,不能同时进行。

并行 (Parallel)

在上面的示例中,虽然三个过程是串行的,但是开发过程本身是可以并行的。比如:

人员分配与任务安排 1天
开发人员1 40天
项目整合 2天
开发人员2 40天
开发人员3 40天
开发人员4 40天
开发人员5 40天

这样除了项目开始的规划用1天和项目整合用2天,这样200人天的工作5个开发人员40天完成,总用时是43天。

小结

最后用几个示例再总结一下四个概念:

  • 小李洗澡完了,再打电话,最后吃东西,这是串行顺发
  • 小李一边洗澡,一边打电话,一边吃东西,这是串行并发,需要指出的是这里的串行的并不是这三个任务,而这三个任务切片后的子任务的串行,即洗澡切片1 -->吃东西切片1--> 打电话切片1 --> 吃东西切片2 --> ...
  • 小李一边洗澡,一边吃东西,而同时小张帮小李打了电话,属于并行

所以,顺发和并发都是单核心的情况,而串行和并行是关于使用CPU核心数量问题:串心是单核心,而并行用了多核心。

最后,再补充一组概述:同步VS异步,强调的是方法调用,以下来自[2]

同步和异步通常用来形容方法的调用方式:

  • 同步方法一旦开始,调用者必须等待方法执行完成,才能继续执行后续方法。
  • 异步方法一旦开始,立即返回,调用者无需等待其中方法执行完成,就可以继续执行后续方法。
    通常我们写的方法都是同步方法,方法间执行都是串行化的,在一个线程内运行。
    举一个例子:
    你和朋友去吃饭,你们到达饭店,点了一桌满汉全席。由于你们饿的不行,就在饭店等待厨师做好菜,等菜上桌。你和你的朋友吃完饭,付了钱,舒舒服服的去商场购物了,一次饭局就结束了。这就是同步调用。
    如今,我们正处在互联网时代,当你们饿的时候,就打开饿了么,点了一桌满汉全席,支付了餐费,这时你就完成了点菜。商家接到了你的订单之后,就会马上开始安排(毕竟顾客就是上帝嘛)。现在你们无须默默等待,以免被饿所折磨,于是你们打开了京东,开始了新的购物。当饿了么小哥饭菜送到时,一签单就完事了,并且你们也完成了购物。这就是异步调用。

参考:
[1] 并发(concurrent)、并行(parallel)、顺序(sequential)、串行(serial)是什么 区别, https://blog.csdn.net/u013288190/article/details/114257211
[2] 同步和异步, https://blog.csdn.net/p_programmer/article/details/80878404

这篇关于示例说明多线程的两组概念:串行VS并行 和 并发VS顺发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/422432

相关文章

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的