multithreading - "thread"(真的)是什么?

标签 multithreading process definition

我一直在努力寻找一个好的定义,并理解线程到底是什么。

看来我一定错过了一些明显的东西,但是每次我读到什么是线程时,它几乎是一个循环定义,la“线程是一个执行线程”或“一种划分运行任务的方法” ”。呃呃。啊?

从我读到的内容看来,线程并不像进程那样具体。其实这只是一个概念。根据我对其工作方式的理解,处理器为程序执行一些命令(称为执行线程),然后当它需要切换到处理其他程序时位,它存储当前正在某处(线程本地存储)执行的程序的状态,然后开始执行其他程序的指令。来回。因此,线程实际上只是当前正在运行的程序的“执行路径之一”的概念。

与流程不同,流程确实是某种东西 - 它是资源等的集合。

作为一个定义的例子,对我并没有多大帮助。 。 .

来自Wikipedia :

"A thread in computer science is short for a thread of execution. Threads are a way for a program to divide (termed "split") itself into two or more simultaneously (or pseudo-simultaneously) running tasks. Threads and processes differ from one operating system to another but, in general, a thread is contained inside a process and different threads in the same process share same resources while different processes in the same multitasking operating system do not."

那么我说得对吗?错误的?线程到底是什么?

编辑:显然,线程也有自己的调用堆栈,因此这在某种程度上是一个具体的事物

最佳答案

线程是一个执行上下文,它是 CPU 执行指令流所需的所有信息。

假设您正在阅读一本书,并且您想立即休息一下,但您希望能够返回并从您停止的确切位置继续阅读。实现此目的的一种方法是记下页码、行号和字数。所以你阅读一本书的执行上下文就是这 3 个数字。

如果您有室友,并且她正在使用相同的技术,那么她可以在您不使用时拿走这本书,并从她停止的地方继续阅读。然后您可以将其收回,并从原来的位置恢复。

线程以同样的方式工作。 CPU 会给您一种它正在同时进行多项计算的错觉。它通过在每次计算上花费一些时间来实现这一点。它可以做到这一点,因为它为每个计算都有一个执行上下文。就像您可以与 friend 分享一本书一样,许多任务可以共享一个 CPU。

在更技术的层面上,执行上下文(因此线程)由 CPU 寄存器的值组成。

最后:线程与进程不同。线程是执行上下文,而进程是与计算相关的一堆资源。一个进程可以有一个或多个线程。

说明:与进程关联的资源包括内存页(进程中的所有线程都具有相同的内存 View )、文件描述符(例如,打开的套接字)和安全凭证(例如,用户的 ID)谁启动了该过程)。

关于multithreading - "thread"(真的)是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5201852/

相关文章:

node.js - 阻止 Node 进程退出的最简单的代码量是多少?

c - 夹板:定义前使用的局部变量

perl - 如何在 Perl 中的调用之间存储每个线程的状态?

java - 由于 system.out.println 语句导致线程运行延迟

process - Contiki编译错误, “ERROR: address 0x820003 out of range at line 1740 of…”

javascript - 访问当前正在执行的 "request"或 "thread"就好像它是 Node.js 中的全局变量一样?

java - 为什么 Thread.sleep() 清除中断标志?

java - 在 if 条件下调用 Java notify()

c++ - 在类模板中定义一个静态数组

scala - 什么是全动力闭合?