1、什么是进程
进程:一个应用程序在处理机上的一次执行过程,它是一个动态的概念(就是正在执行的程序),而线程是进程中的一部分,进程包含多个线程在运行
深挖进程
- 一个进程可以有很多个线程,但至少有一个线程
- 内存是逻辑内存
- 文件/网络句柄就是资源文件
进程有多个线程的场景类比
- 打开一个 微信,就是一个进程
- 很多个聊天框,就是很多个线程在同时运行中
什么是多进程
- 同时运行多个应用程序
- 当你打开电脑,就已经是多进程模式了,同时跑着多个不同的程序
2、什么是线程
线程:指进程内的一个执行的基本单元,也是进程内的一个可调度任务实体
线程深挖
- PC:program contact,存放的是当前下一条执行指令的地址
- TLS:安全传输层协议
- PC 指向内存:相当于操作系统运行的是一个个线程,进程只是容器,指令本身放在内存;同一进程中的线程共享相同的地址空间,因此可以读写同样的数据结构和变量,便于通信
什么是多线程
- 在同一个进程中同时运行多个任务
- 比如:在 qq 和多个人、群同时聊天
3、进程和线程的区别
内存
进程:不共享内存
线程:共享进程的内存空间
作用
进程:是 CPU 资源分配的最小单位,它主要用来就是资源的分配
线程:是 CPU 调度执行的最小单位,它主要用来系统调度
资源
进程:共享系统的文件、网络资源
线程:会共享进程的资源文件
独立
进程:独立存在,有自己的内存地址
线程:不可以独立,必须依赖进程而存在
开销
进程:需要分配内存,开销较大
线程:只需要分配栈和一个 PC,开销比较小
通信
进程:进程间通信比较复杂,因为它的数据空间独立性,需要通过操作系统,基于 socket 的进程间的通信机制
线程:线程间的通信由于多线程共享内存地址空间和数据空间,可直接通信,不必通过操作系统(内核的调度),比较简单
影响关系
进程:进程崩溃之后,在系统保护模式下,不会对其他进程产生影响
线程:一个线程崩溃之后,整个进程都会死掉
总结:多进程比多线程要健壮,一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行