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