Multithreading 如何实现线程库?
编写实现线程库的代码是内核代码的一部分吗?Multithreading 如何实现线程库?,multithreading,operating-system,linux-kernel,Multithreading,Operating System,Linux Kernel,编写实现线程库的代码是内核代码的一部分吗? pthread_create()等的函数实现是内核的一部分吗?线程有时纯粹在用户空间中实现(然后也称为“绿色线程”),但通常在内核空间中实现。在Linux中,pthread\u create()等是作为glibc项目的一部分实现的。它使用(不可移植的、特定于Linux的)系统调用clone()。(Linux的fork()也是根据clone()实现的)。一些BSD也有类似的系统调用,称为rfork() 我的理解是,clone()或rfork()都将创建一
pthread_create()等的函数实现是内核的一部分吗?线程有时纯粹在用户空间中实现(然后也称为“绿色线程”),但通常在内核空间中实现。在Linux中,
pthread\u create()
等是作为glibc项目的一部分实现的。它使用(不可移植的、特定于Linux的)系统调用clone()
。(Linux的fork()
也是根据clone()
实现的)。一些BSD也有类似的系统调用,称为rfork()
我的理解是,clone()
或rfork()
都将创建一个新进程,但您可以指定一个标志,上面写着“使用写时复制语义为其提供不同的地址空间”。因此,如果您想要fork()
,您可以指定该标志,但如果您想要创建线程,则不需要,最终会得到一个共享地址空间
(编辑以提供更多详细信息)