官术网_书友最值得收藏!

Concurrent versus parallel

At this point, if you have had some experience in parallel programming, you might be wondering whether concurrency is any different from parallelism. The key difference between concurrent and parallel programming is that, while in parallel programs there are a number of processing flows (mainly CPUs and cores) working independently all at once, there might be different processing flows (mostly threads) accessing and using a shared resource at the same time in concurrent programs.

Since this shared resource can be read and overwritten by any of the different processing flows, some form of coordination is required at times, when the tasks that need to be executed are not entirely independent from one another. In other words, it is important for some tasks to be executed after the others, to ensure that the programs will produce the correct results.

Difference between concurrency and parallelism

The preceding figure illustrates the difference between concurrency and parallelism: while in the upper section, parallel activities (in this case, cars) that do not interact with each other can run at the same time, in the lower section, some tasks have to wait for others to finish before they can be executed.

We will look at more examples of these distinctions later on.

主站蜘蛛池模板: 安阳县| 安溪县| 全州县| 昔阳县| 夏邑县| 阿克苏市| 舟曲县| 八宿县| 漠河县| 筠连县| 平罗县| 丰镇市| 民丰县| 江源县| 和林格尔县| 玉溪市| 浏阳市| 麦盖提县| 奉节县| 敖汉旗| 江门市| 隆林| 枣庄市| 商水县| 平遥县| 涞水县| 从江县| 长武县| 鹤庆县| 若尔盖县| 关岭| 焉耆| 重庆市| 秦安县| 特克斯县| 寻乌县| 乌拉特中旗| 平利县| 陆河县| 云和县| 托克逊县|