进程 : 是指一段正在执行的程序。
线程: 是指程序正在执行过程中,能够执行程序代码的一个执行单元。
线程有时也被称为轻量级进程,它是程序执行的最小单元,一个进程可以拥有多个线程。各个线程之间共享程序的内存空间(代码段、数据段、堆空间)及一些进程级的资源(例如打开的文件),但是各个线程拥有自己的栈空间。
简单地说,线程所使用的资源来自其所属进程的资源,线程组之间只能共享资源。
扩展:在Java语言中,线程有4种状态:运行、就绪、挂起、结束。
线程与进程的区别:
1)地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。
2)通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。
3)调度和切换:线程上下文切换比进程上下文切换要快得多。
4)在多线程OS中,进程不是一个可执行的实体。
为什么使用多线程?
-
使用多线程可以减少程序的响应时间
-
与进程相比,线程的创建和切换开销更小。
由于启动一个新的进程必须给这个进程分配独立的地址空间;而对线程而言,除了CPU外,系统不会为线程分配内存,运行于同一个进程内的地址空间共享资源,线程的启动或切换比进程要少很多。同时多线程在数据共享方面效率非常高。
-
在多CPU计算机上使用多线程能提高CPU的利用率。
多CPU或多核计算机本身就具有执行多线程的能力,如果使用单线程,将无法重复利用计算机资源,造成资源的巨大浪费。
-
使用多线程能简化程序的结构,使程序便于理解和维护。
一个非常复杂的进程可以分为多个线程来执行