Java 并发/多线程教程(六)-并发VS并行

简介:        本系列译自jakob jenkov的Java并发多线程教程,个人觉得很有收获。由于个人水平有限,不对之处还望矫正!         在多线程线程编程中,我们经常提及并发和并行,但是并发和并行究竟是什么意思,他们所要表达是同一回事,还是不是同一加事。

       本系列译自jakob jenkov的Java并发多线程教程,个人觉得很有收获。由于个人水平有限,不对之处还望矫正!

        在多线程线程编程中,我们经常提及并发和并行,但是并发和并行究竟是什么意思,他们所要表达是同一回事,还是不是同一加事。

       它们当然不是一回事,虽然表面上它们看起来非常的相似,但是它们是两个不相同的术语。在此之前,我也花费了大量的时间去了解并发与并行的区别,因此我觉得在这里对比一下两者。

并发

        并发意味着一个应用在同一时刻处理多个任务。如果计算机只有一个CPU,那么应用程序不可能在同一时刻处理多个任务,但在应用内部,会有多个任务被处理,也就是说一个任务还没有结束的时候另一个任务已经开始被处理。

1240

并行

         并行意味着应用将任务划分成多个小的子任务,去并行的执行。

1240

并发与并行详细对比

        正如你所看到的一样。并发与应用程序如何处理多任务有关,应用程序可以在同一时刻处理一个任务(顺序),也有可能在同一时刻处理多个任务(并发)。并行,换句话来说就是,它与应用程序如何处理每个单独的任务有关。应用程序可以从开始到结束连续处理,或是将任务划分解成多个可以并行运行的子任务。如你所看到的,有些应用程序可以是并发但不是并行的,这就是说同一时刻可以处理多个任务,而这些任务不会分解成多个子任务。应用程序可以是并行的但不是并发的,这就是说同一时刻只有一个任务在执行,任务被分解成多个子任务并行执行。除此,一个应用程序可以既不是并行的,也不不并发的,这就是说,同一时刻只有一个任务执行,而且这个任务绝对不会拆解成多个子任务去并行执行。最后,一个应用程序可以是并行的也可以是并发的,这就是说同一时刻可以有多个任务并发执行,同时每个任务又可以拆解成多个子任务并行的去执行。然而,在这种情况下,并发和并行的优点可能不复存在,因为计算机中CPU已经很繁忙的去处理并发和并行,他们二者的结合可能只会产生较小的性能提升或者甚至降低。因此在选择并发并行模型时,请确保你的分析和度量。

目录
相关文章
|
1天前
|
消息中间件 缓存 NoSQL
Java多线程实战-CompletableFuture异步编程优化查询接口响应速度
Java多线程实战-CompletableFuture异步编程优化查询接口响应速度
|
1天前
|
数据采集 存储 Java
高德地图爬虫实践:Java多线程并发处理策略
高德地图爬虫实践:Java多线程并发处理策略
|
2天前
|
数据采集 前端开发 测试技术
《手把手教你》系列技巧篇(三十一)-java+ selenium自动化测试- Actions的相关操作-番外篇(详解教程)
【4月更文挑战第23天】本文介绍了网页中的滑动验证码的实现原理和自动化测试方法。作者首先提到了网站的反爬虫机制,并表示在本地创建一个没有该机制的网页,然后使用谷歌浏览器进行验证。接着,文章详细讲解了如何使用WebElement的click()方法以及Action类提供的API来模拟鼠标的各种操作,如右击、双击、悬停和拖动。
6 2
|
2天前
|
缓存 Java
【Java基础】简说多线程(上)
【Java基础】简说多线程(上)
6 0
|
3天前
|
安全 Java 编译器
是时候来唠一唠synchronized关键字了,Java多线程的必问考点!
本文简要介绍了Java中的`synchronized`关键字,它是用于保证多线程环境下的同步,解决原子性、可见性和顺序性问题。从JDK1.6开始,synchronized进行了优化,性能得到提升,现在仍可在项目中使用。synchronized有三种用法:修饰实例方法、静态方法和代码块。文章还讨论了synchronized修饰代码块的锁对象、静态与非静态方法调用的互斥性,以及构造方法不能被同步修饰。此外,通过反汇编展示了`synchronized`在方法和代码块上的底层实现,涉及ObjectMonitor和monitorenter/monitorexit指令。
16 0
|
3天前
|
Web App开发 数据采集 Java
《手把手教你》系列技巧篇(三十)-java+ selenium自动化测试- Actions的相关操作下篇(详解教程)
【4月更文挑战第22天】本文介绍了在测试过程中可能会用到的两个功能:Actions类中的拖拽操作和划取字段操作。拖拽操作包括基本讲解、项目实战、代码设计和参考代码,涉及到鼠标按住元素并将其拖动到另一个元素上或指定位置。划取字段操作则介绍了如何在一段文字中随机选取一部分,包括项目实战、代码设计和参考代码。此外,文章还提到了滑动验证的实现,并提供了相关的代码示例。
31 2
|
3天前
|
安全 Java
Java基础教程(15)-多线程基础
【4月更文挑战第15天】Java内置多线程支持,通过Thread类或Runnable接口实现。线程状态包括New、Runnable、Blocked、Waiting、Timed Waiting和Terminated。启动线程调用start(),中断线程用interrupt(),同步用synchronized关键字。线程安全包如java.util.concurrent提供并发集合和原子操作。线程池如ExecutorService简化任务管理,Callable接口允许返回值,Future配合获取异步结果。Java 8引入CompletableFuture支持回调。
|
4天前
|
XML 算法 搜索推荐
Java 中文官方教程 2022 版(四十九)(4)
Java 中文官方教程 2022 版(四十九)
31 0
|
4天前
|
XML 自然语言处理 安全
Java 中文官方教程 2022 版(四十九)(3)
Java 中文官方教程 2022 版(四十九)
22 0
|
4天前
|
XML Java 编译器
Java 中文官方教程 2022 版(四十九)(2)
Java 中文官方教程 2022 版(四十九)
24 0

热门文章

最新文章