并发和并行都可以表示执行多个任务,但是偏重点不同.并发偏重于多个任务交替执行,而多个任务之间有可能是串行的.并行是真正意义上的同时执行. 并发和并行示意图如下: 从严格意义上来说,并行的多个任务是真实的同时执行,而并发的多个任务是交替执行,一会儿运行任务A一会儿运行任务B,系统会不停地在多个任务之间切换.但对于外部观察者来说,即使多个任务之间是串行并发的,也会产生多个任务之间是并行执行的错觉.并行只能出现在多核CPU,因为一个CPU一次只能执行一条指令. 参考资料 <实战Java高并发程序设计>…