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;
 }

 

posted @ 2016-06-26 15:39  VinoZhu  阅读(2185)  评论(0编辑  收藏  举报