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

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.

主站蜘蛛池模板: 徐州市| 天气| 栾城县| 清镇市| 新绛县| 邓州市| 新营市| 龙海市| 鄂尔多斯市| 西城区| 北流市| 海阳市| 海晏县| 左云县| 红安县| 温宿县| 翼城县| 靖州| 河曲县| 吴堡县| 广灵县| 桐乡市| 汤原县| 涿州市| 文山县| 夹江县| 敦化市| 涞源县| 双城市| 揭西县| 辽阳县| 琼中| 开封市| 嵊州市| 稻城县| 奎屯市| 政和县| 德安县| 牟定县| 遂平县| 河曲县|