linux内核——进程,轻量级进程,线程,线程组

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux内核——进程,轻量级进程,线程,线程组相关的知识,希望对你有一定的参考价值。

1、进程、轻量级进程、线程、线程组之间的关系

2、及它们的标识相关说明

一、进程、轻量级进程、线程、线程组之间的关系

借助上图说明:

进程P0有四条执行流,即线程,

主线程t0是它的第一个线程,且与进程P0相关联,

之后衍生出t1、t2、t3三个线程,这三个线程与轻量级进程P1、P2、P3一一关联,

所有的进程、轻量级进程、线程组成了线程组。

轻量级进程也是进程,只不过它与某进程的某特定线程相关联。

二、它们的标识相关说明

pid是进程标识符,tgid是线程组标识符

每个进程都有自己的pid,如图中:进程pid(P0)= a,轻量级进程pid(P1)= b / pid(P1)= c / pid(P1)= d。

同属于一个线程组的所有进程、轻量级进程有同样的线程组标识符,且其为第一个线程所关联的进程标识符,

例如:图中第一个线程为t0,它所关联的进程为P0,pid(P0)= a,所以tgid(P1)= a / tgid(P1)= a / tgid(P1)= a / tgid(P1)= a。

当我们使用函数getpid(current_p)时,返回值不是current_p的pid,而是它的tgid。(current_p为当前进程)。

 

这一点,可以从系统调用getpid和gettid中看出来(位于kernel/timer.c)。

  asmlinkage long sys_getpid(void)
  {
    return current->tgid;
  }
 asmlinkage long sys_gettid(void)
 {
   return current->pid;
 }

 

以上是关于linux内核——进程,轻量级进程,线程,线程组的主要内容,如果未能解决你的问题,请参考以下文章

《Linux内核设计与实现》读书笔记- Linux的进程

《内核设计与实现》读书笔记- 进程管理

JVM线程与Linux内核线程的映射(关系)

Java线程与锁

Linux 内核:线程与进程 - task_struct 与 thread_info

学习笔记 深入理解Linux内核第三版 —— 第三章 进程