定义:
进程是一个计算机程序的实例,由一个或者多个线程组成.
线程的执行是由计算机的fork操作来将一个程序生成一个或者多个并发的运行任务.
联系:
通常, 一个进程可以包括多个线程, 一个线程只能属于一个进程.
本质区别:
是否共享地址空间,及共享多少地址空间.(内核系统下实际上没有本质的区别)
传统意义上, 进程之间是不共享地址空间的, 而线程是共享着进程的地址空间.
在多进程情况下,每个进程都有自己的独立空间,而多线程情况下,同一进程内的线程共享进程的空间地址。因此,创建一个新的进程时就要耗费时间来为其分配系统资源,而创建一个新的线程花费的时间要少的多
在系统调度方面,由于进程地址空间独立而线程共享地址空间,线程间的切换速度要远远快于进程间的切换
在通信机制方面,进程间数据相互独立,彼此间通信要以专门的通信方式进行,通信时必须经过操作系统,而线程是数据共享的。