学习多线程的时候会遇到一个名词:并发。这是属于操作系统中的词汇,需要了解并发和并行的区别,从网上搜集了几种说法帮助理解。
一:
并发是指一个处理器同时处理多个任务。
并行是指多个处理器或者是多核的处理器同时处理多个不同的任务。
并发是逻辑上的同时发生(simultaneous),而并行是物理上的同时发生。
来个比喻:并发是一个人同时吃三个馒头,而并行是三个人同时吃三个馒头。
二:
并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。就好像两个人各拿一把铁锨在挖坑,一小时后,每人一个大坑。所以无论从微观还是从宏观来看,二者都是一起执行的。

并发(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个进程快速交替的执行。这就好像两个人用同一把铁锨,轮流挖坑,一小时后,两个人各挖一个小一点的坑,要想挖两个大一点得坑,一定会用两个小时。

并行在多处理器系统中存在,而并发可以在单处理器和多处理器系统中都存在,并发能够在单处理器系统中存在是因为并发是并行的假象,并行要求程序能够同时执行多个操作,而并发只是要求程序假装同时执行多个操作(每个小时间片执行一个操作,多个操作快速切换执行)。
三:
当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状态.这种方式我们称之为并发(Concurrent)。

当系统有一个以上CPU时,则线程的操作有可能非并发.当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)。

原文链接:https://blog.csdn.net/java_zero2one/article/details/51477791

并发与并行的区别(超级通俗易懂)相关推荐

  1. 转:并发与并行的区别

    转: https://www.jianshu.com/p/b11e251d3dc7 并发:一个处理器同时处理多个任务.(concurrency) 单个cpu逻辑上同时处理多个任务: 并行:多个处理器或 ...

  2. 如何向纯洁的女朋友解释并发与并行的区别?

    原文链接:并发与并行的区别 现在我们都说设计可并行.高并发的程序,而且我们很多时候会在潜意识里觉得自己对并行(Parallelism)和并发(Concurrency)的区别很清楚,但如果要明确的说出二 ...

  3. java并发和并行的区别

    概念: 并发:以交替的方式 利用等待某件事情完成的时间  来做其他事情,轮流执行任务,不一定同时.宏观上同时,微观上依次执行. 并行:在同一时刻,任务同时开始进行,彼此没有依赖关系.多个任务同一时刻同 ...

  4. 操作系统中并发和并行的区别和联系

    多线程中并发和并行有区别吗? 搞不懂并发和并行分别是什么意思? 一文通俗的解释并发和并行的区别和联系. 本人一直以为并发和并行是一个意思,直到偶然从站长公众号上看到了并发和并行的区别一文,因此做个笔记 ...

  5. 多线程并发和并行的区别

    背景  对于java开发从业人员来说,并发编程是绕不开的话题,juc并发包下提供了一系列多线程场景解决方案.  随着jdk1.8的普及,多线程处理问题,除了使用使用线程池(ExecutorServic ...

  6. 并发和并行的区别_多核、多处理器、并发、并行、超线程概念总结

    多核与多处理器 多核( ) 多核处理器就是指单个 CPU 中有多个可执行单元. 如下图所示,单个 CPU 中有两套可执行单元. 多处理器( ) 多处理器系统则是一个拥有多个 CPU 的系统.每个 CP ...

  7. 程序与进程的区别,并发与并行的区别,多进程的实现原理

    目录 1. 什么是进程 2. 进程与程序的区别 3. 并发与并行 4. 同步\异步and阻塞\非阻塞(重点) 5. 进程的创建(了解) 6. 进程的终止(了解) 7. 进程的层次结构 8. 进程的状态 ...

  8. 简单了解线程和进程、多进程和多线程、并发和并行的区别

    一:线程与进程 1.概念 线程:是程序执行流的最小单元,是系统独立调度和分配CPU(独立运行)的基本单位. 进程:是资源分配的基本单位.一个进程包括多个线程. 2.区别: 1.线程与资源分配无关,它属 ...

  9. 纠错--并发和并行的区别

    并行性和并发性是既相似又有区别的两个概念,再开始分析之前,我们先给出并发和并行的概念. ​ 并行是指两个或多个事件在同一时刻发生. ​ 并发是指两个或多个事件在同一时间间隔内发生. ​ 大家看到的图一 ...

最新文章

  1. 什么镜头最适合拍风景_双11大促 如何挑选最适合自己的第二支镜头?
  2. cornerstone 忽略不必要文件
  3. Android7.1update.zip升级在system/bin下新增可执行文件没有可执行权限问题
  4. Eclipse for Android 开发环境搭建及各种坑
  5. mq多个消费者消费一个消息_一个普通消费者的米家产品使用感受
  6. JQuery常用选择器总结
  7. Android Paint类属性说明
  8. 确保大数据安全的5个最佳实践措施
  9. 谈谈R中的乱码(二)
  10. flash mx拖拽实例_Flash MX 2004的注释添加器面板
  11. python程序代码大全-Python编程代码示例 - 全文
  12. 国图软件无法生成地籍调查表
  13. MQTT测试工具推荐
  14. (图文详细)设置文件夹中的文件显示文件后缀名的方法
  15. 数据血缘全方位理解实施指南
  16. PC端微信聊天记录备份文件在哪儿?
  17. 微信小程序开发工具取消用户授权
  18. 帝国CMS仿玩游戏网源码大型游戏资讯网站源码
  19. 入职阿里巴巴,成为年薪百万阿里P7高级架构师需要必备哪些技术栈
  20. 利用阿里大鱼发送短信验证

热门文章

  1. 用Python爬虫来爬写真网图片
  2. linux下用c语言编写99乘法表,C语言输出九九乘法表(5种解法)
  3. 最好的日子,是用心在一人一事
  4. MMGG吃螃蟹 | Solana上去中心化结构性产品-Exotic
  5. PKI 公钥基础设施原理与应用
  6. Cris 的 Python 数据分析笔记 04:NumPy 矩阵的复制,排序,拓展
  7. siki Unity - A计划
  8. 内推 | 商汤科技计算机视觉岗(全职/实习),可直通面试
  9. 星期五计算机,黑色星期五之夜电脑人
  10. [转载]用户界面设计原则-Jakob Nielson