进程和线程
进程,是操作系统进行资源分配和调度的基本单位。每个进程由PCB,程序,数据组成,具有自己的实体空间,
线程,是cpu能够运算调度的基本单位。一个进程中的所有线程共享这个进程的所有资源,同时,这些线程又在进程中拥有各自的空间,有自己的控制表TCB,堆栈(系统栈和用户栈)(相对来说很小),一个进程可以并发多个线程,每个线程执行不同的任务。没有线程的进程可以看作单线程。
这,正是多任务操作系统的实现的基础。
打开一个浏览器,就产生了一个浏览器进程,打开一个word产生了一个word进程。如果没有线程的存在,那么就不能同时在一个进程中执行多个任务。现在的cou普遍都是多核多线程的,在实际使用过程中,因为任务数量很多,远远大于cpu的核心数,操作系统将这些任务轮流调度到cpu的核心上运行。
二者的比较:
线程只代表了cpu执行过程的改变,进程的实际资源并没有发生变化,线程依赖进程而不会独立存在,是进程的一部分。
进程之间各自独立,而同一进程的线程所有资源共享。进程内的线程对其他进程不可见。