What is the difference between concurrency and parallelism?
(并发和并行性有什么区别?)
Examples are appreciated.
(示例被赞赏。)
ask by StackUnderflow translate from soWhat is the difference between concurrency and parallelism?
(并发和并行性有什么区别?)
Examples are appreciated.
(示例被赞赏。)
ask by StackUnderflow translate from soConcurrency is when two or more tasks can start, run, and complete in overlapping time periods.
(并发是指两个或多个任务可以在重叠的时间段内启动,运行和完成。)
It doesn't necessarily mean they'll ever both be running at the same instant.(并不一定意味着它们都将同时运行。)
For example, multitasking on a single-core machine.(例如,单核计算机上的多任务处理 。)
Parallelism is when tasks literally run at the same time, eg, on a multicore processor.
(并行是指任务实际上在多核处理器上同时运行。)
Quoting Sun's Multithreaded Programming Guide :
(引用Sun的《 多线程编程指南》 :)
Concurrency: A condition that exists when at least two threads are making progress.
(并发:至少有两个线程在进行时存在的条件。)
A more generalized form of parallelism that can include time-slicing as a form of virtual parallelism.(并行性的一种更通用的形式,可以包括时间切片作为虚拟并行性的一种形式。)
Parallelism: A condition that arises when at least two threads are executing simultaneously.
(并行性:当至少两个线程同时执行时出现的条件。)