一、进程和线程对比认识
进程是系统进行资源分配的基本单位,线程是被系统独立调度和执行的基本单位。
进程可以看作是程序的一个实例,线程是属于进程的,一个进程可以包含多个线程。
与进程不同的是同类的多个线程共享进程的堆和方法区资源,但每个线程有自己的程序计数器、虚拟机栈和本地方法栈,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。
进程的特征:并发性,异步性,动态性,独立性,结构性
线程的作用:使多道程序更好的并发执行,提高资源利用率和系统吞吐量,增强操作系统的并发性能。
进程基本上是相互独立的,而线程存在于进程内,是进程的一个子集。
进程拥有共享的资源,比如内存空间,可以让其内部的线程集合共享使用。
进程间通信较为复杂,进程间的通信 IPC(Inter-process communication)
线程通信相对简单,因为它们共享进程内的内存。
- 多个线程可以访问同一个共享变量Java 中的通信机制:volatile、等待/通知机制、join方式、InheritableThreadLocal、MappedByteBuffer
线程的上下文切换要比进程的上下文切换成本低。
二、 并发和并行
解释一:并发是两件或多件事情在同一时间内交替发生;并行是两件或多件事情在同一时间内同时发生。
解释二:并发在同一时刻,有多个指令在单个 CPU 上交替执行 ;并行是在同一时刻,有多个指令在多个 CPU 上同时执行。
解释三:并发是不同代码块交替执行;并行是不同代码块同时执行。
并发中的交替的时间非常短,具体和CPU调度有关。
三、 同步和异步
同步是需要等待结果的返回才能继续执行;异步是不需要等待结果的返回就能执行。