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

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

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

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

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

并发

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

1240

并行

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

1240

并发与并行详细对比

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

目录
相关文章
|
5天前
|
Java 程序员 API
Java并发基础:concurrent Flow API全面解析
java.util.concurrent.Flow定义了响应式编程的核心接口,促进了Java在异步数据处理和背压机制方面的标准化,这使得第三方库如Reactor和RxJava能够基于这些接口提供丰富的实现和功能,同时简化了响应式编程在Java中的使用,Flow API增强了Java在并发编程领域的灵活性,使得处理异步数据流变得更加自然和高效。
Java并发基础:concurrent Flow API全面解析
|
9天前
|
安全 Java API
Java并发基础:Exchanger全面解析!
Exchanger类的优点在于能够简洁高效地实现两个线程间的数据交换,通过Exchanger,开发者可以避免复杂的锁和同步机制,降低并发编程的难度,同时,它还提供了线程安全的数据交换保障,使得多线程协作更为可靠、易用性和高效性。
Java并发基础:Exchanger全面解析!
|
2天前
|
缓存 安全 算法
Java并发基础:原子类之AtomicInteger全面解析
【2月更文挑战第2天】AtomicInteger类提供了线程安全的整数操作,它通过利用底层硬件的原子性指令,能够在多线程环境中高效地实现整数的无锁更新,避免了传统同步机制带来的性能开销,在高并发场景下成为计数器可大幅提高程序的执行效率,同时又保证了数据一致性。
28 15
Java并发基础:原子类之AtomicInteger全面解析
|
3天前
|
存储 算法 安全
Java并发基础:原子类之AtomicBoolean全面解析
【2月更文挑战第1天】 AtomicBoolean类优点在于能够确保布尔值在多线程环境下的原子性操作,避免了繁琐的同步措施,它提供了高效的非阻塞算法实现,可以大大提成程序的并发性能,AtomicBoolean的API设计非常简单易用。
Java并发基础:原子类之AtomicBoolean全面解析
|
3天前
|
Java
如何在Java中使用多线程提高程序性能
【2月更文挑战第2天】在当今的计算机应用领域中,性能是一个不可忽视的重要因素。为了提高程序的性能,我们可以采用多种方法。其中一种方法是使用多线程。本文将介绍如何在Java中使用多线程来提高程序性能。
12 2
|
3天前
|
数据采集 Java API
Java并发基础:CyclicBarrier全面解析!
CyclicBarrier的优点在于实现了线程间的相互等待与协同,确保所有线程在达到预定屏障点后才能继续执行,它支持屏障的重复使用,非常适合多轮次的任务同步,此外,CyclicBarrier还允许在屏障点执行特定操作,为复杂的多线程协作提供了便利。
Java并发基础:CyclicBarrier全面解析!
|
5天前
|
XML 监控 druid
【Java专题_02】springboot+mybatis+pagehelper分页插件+druid数据源详细教程
【Java专题_02】springboot+mybatis+pagehelper分页插件+druid数据源详细教程
27 0
|
5天前
|
Java easyexcel Maven
【Java专题_04】集成EasyExcel进行Excel导入导出详细教程
【Java专题_04】集成EasyExcel进行Excel导入导出详细教程
9 0
|
5天前
|
存储 安全 Java
Java并发基础:CopyOnWriteArraySet全面解析
CopyOnWriteArraySet类的优点在于能够实现无锁读取,确保高并发下的读取性能,同时,写操作通过复制底层数据来保证数据一致性,避免了多线程间的数据冲突,因此,它非常适合读多写少且对数据一致性要求较高的场景。
Java并发基础:CopyOnWriteArraySet全面解析
|
5天前
|
存储 监控 算法
深入探究Java线程池:提升并发性能的利器
深入探究Java线程池:提升并发性能的利器
73 0

相关产品

  • 云迁移中心