一、问题综述
进程是 系统进行 资源分配 和 调度 的基本单位。
线程 Thread 是 操作系统能够 进行运算调度的 最小单位,线程是 进程的 子任务,是进程内的 执行单元。
一个进程 至少有一个线程,一个 进程可以 运行多个线程,这些线程 共享同一块 内存。
资源开销:
- 进程:由于 每个进程都有 独立的 内存空间,创建 和 销毁 进程的 开销较大。进程间 切换 需要 保存 和 恢复 整个进程的 状态,因此 上下文切换 的 开销较高。
- 线程:线程 共享相同的 内存空间,创建 和 销毁线程的 开销较小。线程间 切换 只需要 保存 和 恢复少量 的线程上下文,因此 上下文切换的 开销较小。
通信与同步:
- 进程:由于 进程间 相互隔离,进程之间的 通信需要 使用一些 特殊机制,如 管道、消息队列、共享内存 等。
- 线程:由于 线程共享相同的 内存空间,它们之间 可以 直接访问 共享数据,线程间通信 更加方便。
安全性:
- 进程:由于 进程间 相互隔离,一个进程的 崩溃不会 直接影响 其他进程的 稳定性。
- 线程:由于 线程共享相同的 内存空间,一个线程的 错误可能会 影响整个进程的 稳定性。