并行和并发这个条目经常使用在有关于多线程程序中。但是并行和并发确切的含义是什么呢?以及他们是相同的或者什么?
最简单的回答是“不”。他们不是相同的词条,虽然他们在表面上看起来非常相似。它也花费了我一些时间去发现理解他们之间的不同。因此我决定在本教程中添加一篇关于他们的主题。
并发
并发意味着一个应用同时运行不止一个任务。如果计算机只有一个CPU,应用可能同时不会真正的运行超过一个程序,但是在应用的内部每次有不止一个程序被运行了。在它开始下一个之前,它不能完全的结束一个任务。
.
并行
并行意味着应用程序把他的任务分成小的子任务,这些子任务可以并行的运行,例如在确定的同时的多个CPU上。
并发和并行的详细比较
正如你看到的,并发是一个应用如何处理多个任务。应用程序可以顺序的执行任务或者并发的同时执行多个任务。
并行换句话说,是关于一个应用如何处理一个单独的任务。应用程序可能从开始到结束连续的执行这个任务,或者分离这个任务为多个子任务可以去并行的运行的。
正如你看到的,一个应用可以是并发的,但是不能并行的。这就意味着它同时执行超过一个任务,但是这个任务不能分离成子任务。
一个应用也可以是并行的而不是并发的。这就意味着这个应用同时执行一个任务,并且这个任务被分离成多个子任务去并行的运行。
另外的,一个应用可以既不是并发的也不是并行的。这就意味着这个应用只是同时工作在一个任务上,并且这个任务不会被分离成子任务。
最后,一个应用既可以是并发也可以是并行的,这样的情况下,它可以同时既工作在多个任务上,也可以把每一个任务分离成多个子任务去并行的执行。然而,在这个场景中并发和并行的一些好处可能会丢失掉,因为在计算机中的CPU对于并发或者并行已经保持相当的繁忙了。他们两个组合使用可能会有一个小的性能提升或者甚至是性能丢失。在你盲目的采用并发并行模型之前,你需要确认分析和衡量好。
以上就是Java 并发对并行的详细介绍的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!