概述
几乎所有的操作系统都支持同时运行多个任务,一个任务通常就是一个程序,乜咯运行中的程序就是一个进程。当一个程序运行时,内部可能包括多个顺序执行流,每个顺序执行流就是一个进程
什么是进程
正在运行中的应用程序,通常称为进程。每个进程都有自己独立的地址空间(内存空间),每当用户启动一个进程时,操作系统就会为该进程分配一个独立的内存空间,让应用程序在这个独立的内存空间中运行
什么是线程
线程是一个轻量级的子进程,是最小的处理单元;是一个单独的执行路径。可以说:线程是进程的子集(部分)。
线程是独立的。如果在一个线程中发生异常,则不会影响其他线程。它使用共享内存区域
进程和线程的关系
操作系统中可以拥有多个进程,一个进程里可以拥有多个线程,线程在进程内执行
进程和线程的区别
- 容易创建新线程。创建新进程需要重复父进程
- 线程可以控制同一进程的其他线程。进程无法控制兄弟进程,只能控制其子进程
- 进程拥有自己的内存空间。线程使用进程的内存空间,且要和该进程的其他线程共享这个空间;而不是在进程中给每个线程单独划分一点空间。
- (同一进程中的)线程在共享内存空间中运行,而进程在不同的内存空间中运行
- 线程可以使用wait(),notify(),notifyAll()等方法直接与其他线程(同一进程)通信;而,进程需要使用“进程间通信”(IPC)来与操作系统中的其他进程通信