Linux中线程即轻量级进程(LWP),由task_struct表示,与进程无本质区别;pthread_create()通过clone()系统调用创建共享资源的LWP,各线程有独立tid但同属一个tgid,调度以LWP为单位。

在Linux中,线程(Thread)本质上就是轻量级进程(LWP,Lightweight Process),二者没有本质区别,都是由内核调度的基本单位——task_struct结构体实例来表示。
线程在内核中以进程形式存在
Linux内核并不区分“线程”和“进程”的概念,统一使用task_struct描述每个可调度实体。当调用pthread_create()创建线程时,glibc实际通过clone()系统调用,并传入共享内存、文件描述符、信号处理等标志(如CLONE_VM、CLONE_FILES、CLONE_SIGHAND),让新任务与父任务共享大部分资源,仅独立拥有栈、寄存器状态和tid(线程ID)。
- 每个线程都有唯一的tid(线程ID),对应/proc/[pid]/task/[tid]目录
- 主线程的tid == pid;其他线程的tid与pid不同,但属于同一进程组(tgid == pid)
- ps -eLf显示的LWP列即为tid,而PID列为tgid(线程组ID)
LWP是用户空间对内核task的映射视角
“轻量级进程”这一术语源于早期POSIX线程实现(如LinuxThreads),强调其比传统fork()产生的进程开销更小。现代NPTL(Native POSIX Thread Library)虽已优化,但“LWP”仍被沿用,指代内核中那些与其它task共享地址空间的可调度实体。
- 一个进程(tgid)可包含多个LWP(多个tid),它们共用虚拟内存、打开的文件、工作目录等
- 信号可发给整个线程组(tgid),也可精确投递给某一线程(tid)
- 线程间同步(如互斥锁、条件变量)依赖用户态+内核态协作,但调度、抢占、上下文切换均由内核按LWP粒度完成
关键区别仅在于资源共享粒度
所谓“进程”与“线程”,在Linux中只是clone()调用时传入的标志位不同:
- 普通进程:fork() → 相当于clone(SIGCHLD),几乎不共享资源
- 线程:pthread_create() → 相当于clone(CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND | ...),高度共享
- 二者都生成新的task_struct,都参与CFS调度,都拥有独立的内核栈和thread_info
验证方式:观察/proc文件系统
运行一个多线程程序后,可通过以下命令直观确认:
- ls /proc/[pid]/task/ —— 列出所有LWP(每个子目录名即为tid)
- cat /proc/[pid]/status | grep -E "(Tgid|Pid|PPid)" —— 查看线程组ID与当前tid关系
- ps -o pid,tid,comm -T -p [pid] —— 显示该进程下所有线程的pid(tgid)、tid及名称










