浅谈对Java多线程的理解

Java多线程

  先来区分一下并行和并发这两个概念:

  • 并发:
    指一个处理器同时处理多个任务,但指的是有处理多个任务的能力而非真的实在同一时间点同时处理。其实CPU是在多个任务间进行快速交替,由于速度极快,使得我们认为它们是在同时运行。
  • 并行:
    指的是两个或两个以上事件在同一时刻发生,这是物理上真正的同时发生。比如有多条指令在多个处理器核心上同时执行,在多道程序环境下,并行使得多个程序在同一时刻可在不同CPU上同时执行。
  多线程情况下:
  • 若系统只有一个CPU(核心),那么它不可能真正意义上,在物理层面上去同时进行一个以上的线程/进程。它只能把CPU运行时间划分成若干个时间段,再将时间片段分配给不同的线程执行。在一个时间片段里运行代码时,其他线程则处于挂起状态,这就叫并发(Concurrent)
  • 系统有多个CPU(核心),线程的操作可能非并发,当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程不必抢夺CPU时间,可以真正的在物理层面实现同时执行,这种的我们称之为并行。
    浅谈对Java多线程的理解_第1张图片

你可能感兴趣的:(Java开发进阶,java,多线程,并发)