1.并行和并发
并行:即同时进行,指在同一时刻,有多条指令在多个处理器上同时执行。所以无论从微观还是从宏观来看,二者都是一起执行的。
并发:指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个进程快速交替的执行。
2.并发的三大特性(可见性、有序性、原子性)
JMM内存模型
1.0.可见性
当一个线程修改了共享变量的值,其他线程能够看到修改的值。 Java内存模型是通过在变量修改后将新值同步回主内存,在变量读取前从主内存刷新变量值这种依赖主内存作为传递媒介的方法来实现可见性的。
2.0.有序性
程序执行的顺序按照代码的先后顺序执行。JVM 存在指令重排,所以存在有序性问题。
3.0.原子性
一个或多个操作,要么全部执行且在执行过程中不被任何因素打断,要么全部不执行。在 Java中,对基本数据类型的变量的读取和赋值操作是原子性操作(64位处理器)。不采取任何的原子性保障措施的自增操作并不是原子性的。
并行是指在同一时刻多条指令在多个处理器上同时执行,而并发则是在宏观上看似多条指令同时执行,但实际上是在快速交替执行。Java内存模型(JMM)确保了并发执行时的可见性,即线程修改的共享变量对其他线程可见,但不保证有序性,因为存在指令重排。原子性是指操作不可中断,Java中的基本类型读写是原子性的,但复合操作如自增可能需要额外的原子性保障。
509

被折叠的 条评论
为什么被折叠?



