java面试题:讲一讲进程,线程,协程

本文仅仅是梳理面试遇到这个题目的答题过程梳理

1. 进程和线程的区别

1)进程是资源分配的基本单位,线程是任务调度的基本单位。
2)从包含关系来看,一个进程中可以包含多个线程。
3)从内存分配来看,一个进程拥有自己一套独立地址空间和内存,不同进程之间的资源独立。而一个进程中的多个线程共享虚拟地址空间和部分资源。
4)从健壮性来看,一般不同进程之间的影响较小,而线程之间的影响较大,某个线程挂掉可能会导致该进程或线程挂掉,因此进程的健壮性更好。
5)从资源开销来看,进程的切换比线程的切换开销较大。

这里就要注意一个点了,开始可以详细讲一下为什么进程的切换比线程的切换开销大。

2. 进程切换和线程切换的区别

进程切换的三个步骤:

  • 从用户态转内核态
  • 切换新的页表,然后使用新的虚拟地址空间
  • 上下文的切换,指的是栈,寄存器中的数据替换等操作。

线程切换的一个步骤:

  • 从用户态转内核态
  • 上下文切换,指的是栈,寄存器中的数据替换等操作。

这里要注意的是进程和线程的切换都需要转到内核态进行操作,因此线程切换之所以消耗资源较小的原因就在于多线程共享虚拟地址空间,不需要进行页表的切换。而往往页表的切换比较消耗资源。

3. 协程和线程的区别

一般认为一个线程包含多个协程,但是实际上协程可以看做用户态的线程,因此协程的切换比线程切换消耗的资源更小,不涉及用户态和内核态的转换。