进程
也就是系统中运行一个程序, 程序一旦运行就相当于一个进程
每一个进程都有自己独立的地址空间, 如果想要进程访问另一个进程的资源就需要进程间的通信
所谓进程间通信(操作系统提供的进程间通信具体实现方式有很多种: 管道,消息队列,共享信息,信号..),就是隔离性的前提之下,找下一个公共的区域,让两个进程借助这个公共区域(也就是通信方式)来完成数据交换.
线程
线程是进程的一个实体,是进程的一条执行路径 就比如: QQ 有很多功能 如果全是进程的话
创建进程的开销(体现在资源分配 )会很大 , 此时 QQ 内的 聊天功能, 拍照功能, 红包功能..等等都是由线程来处理的,因为线程的开销比进程小很多.
线程 和 进程的区别
进程包含线程,一个进程里面可以有一个线程,也可以有多个线程.
进程有自己独立的内存空间和文件描述符,同一个进程中的多个线程之间 共享同一份地址空间和文件描述符表(所谓文件描述表符 就是文件在硬盘上存储的数据就是以文件来存储的,进程运行的时候 使用了哪些 硬盘上的资源)
操作系统创建进程, 要给进程分配资源(内存, CPU , 硬盘),进程是操作系统分配资源的基本单位.
操作系统创建的线程,是要在CPU上调度执行,线程是操作系统调度执行的基本单位
进程之间具有独立性,一个进程挂了,不会影响到别的进程,同一个进程里的多个线程之间,一个线程挂了,会影响到其他的线程
进程和线程都是为了处理并发编程这样的场景.
但是 进程有问题 : 频繁创建和释放的时候效率低 相比之下 线程更加轻量,创建和释放效率更高(因为减少了释放资源的过程.)