Stvlpotapov Asked:2020-12-11 16:24:18 +0800 CST2020-12-11 16:24:18 +0800 CST 2020-12-11 16:24:18 +0800 CST 轻量级线程的定义是什么意思? 772 协程,顾名思义,是轻量级线程,“不像普通线程那样使用那么多资源”。你能解释一下轻量级线程的定义是什么意思吗? kotlin 1 个回答 Voted Best Answer Mark Shevchenko 2020-12-11T18:15:17+08:002020-12-11T18:15:17+08:00 不同的语言为此提供了不同的手段,因此定义可能会有所不同。 一般而言,轻量级线程的概念与普通线程或操作系统进程相反。 线程存在的先决条件是支持处理器级别的抢占式多任务。在遇到一个特殊指令时,处理器可以将其当前状态存储在内存中并加载另一个状态。例如,您可以在硬件上下文切换部分阅读详细信息。 由于 SS、CS ESP、EIP 寄存器(64 位机器中的 RSP、RIP)是状态的一部分,因此上下文切换会导致处理器开始执行其他指令并使用不同的堆栈。 切换的主要问题是它需要相对较长的时间。此外,每个线程都需要自己的堆栈——Richter 写道,Windows 为每个线程分配 1MB 的 RAM。 最后,不同优先级的线程越多,操作系统切换它们的时间就越长。事实证明,尽管线程允许代码并行工作,但它们会浪费性能。 出路是在物理线程的框架内执行几个独立的小段代码。这种机制以不同的方式实现。 有一种 Go 方法,其中两个程序可以将控制权相互转移。语言和编译器级别支持此功能。 有异步编程,它在操作系统级别得到支持。特别是在 Windows 上,线程可以在称为alertable的特殊状态下挂起(进入睡眠状态) ,在俄语中类似于焦虑睡眠。在一个特殊的线程队列中,您可以将在线程进入令人不安的睡眠时依次执行的函数的地址放入。 物理上轻量级的线程仍然在某些操作系统线程上运行。它们一个接一个地依次执行,而不是并行执行。没有上下文切换,所以几乎没有开销。 重要的是,这段代码应该相对小而快,并且不应该阻塞物理线程的执行。也就是说,它们非常适合某些场景,但不是全部。
不同的语言为此提供了不同的手段,因此定义可能会有所不同。
一般而言,轻量级线程的概念与普通线程或操作系统进程相反。
线程存在的先决条件是支持处理器级别的抢占式多任务。在遇到一个特殊指令时,处理器可以将其当前状态存储在内存中并加载另一个状态。例如,您可以在硬件上下文切换部分阅读详细信息。
由于 SS、CS ESP、EIP 寄存器(64 位机器中的 RSP、RIP)是状态的一部分,因此上下文切换会导致处理器开始执行其他指令并使用不同的堆栈。
切换的主要问题是它需要相对较长的时间。此外,每个线程都需要自己的堆栈——Richter 写道,Windows 为每个线程分配 1MB 的 RAM。
最后,不同优先级的线程越多,操作系统切换它们的时间就越长。事实证明,尽管线程允许代码并行工作,但它们会浪费性能。
出路是在物理线程的框架内执行几个独立的小段代码。这种机制以不同的方式实现。
有一种 Go 方法,其中两个程序可以将控制权相互转移。语言和编译器级别支持此功能。
有异步编程,它在操作系统级别得到支持。特别是在 Windows 上,线程可以在称为alertable的特殊状态下挂起(进入睡眠状态) ,在俄语中类似于焦虑睡眠。在一个特殊的线程队列中,您可以将在线程进入令人不安的睡眠时依次执行的函数的地址放入。
物理上轻量级的线程仍然在某些操作系统线程上运行。它们一个接一个地依次执行,而不是并行执行。没有上下文切换,所以几乎没有开销。
重要的是,这段代码应该相对小而快,并且不应该阻塞物理线程的执行。也就是说,它们非常适合某些场景,但不是全部。