- 与进程(process)类似,线程(thread)是允许应用程序并发执行多个任务的一种机制。一个进程可以包含多个线程。同一个程序中的所有线程均会独立执行相同程序,且共享同一份全局内存区域,其中包括初始化数据段、未初始化数据段,以及堆内存段。(传统意义上的 UNIX 进程只是多线程程序的一个特例,该进程只包含一个线程)
- 进程是 CPU 分配资源的最小单位,线程是操作系统调度执行的最小单位。
- 线程是轻量级的进程(LWP:Light Weight Process),在 Linux 环境下线程的本质仍是进程。
- 查看指定进程的 LWP 号:
ps –Lf *pid*
线程和进程的区别
- 进程间的信息难以共享
- 由于除去只读代码段外,父子进程并未共享内存,因此必须采用一些进程间通信方式在进程间进行信息交换。
- 调用 fork() 来创建进程的代价相对较高
- 即便利用写时复制技术,仍然需要复制诸如内存页表和文件描述符表之类的多种进程属性,这意味着 fork() 调用在时间上的开销依然不菲。
- 线程之间能够方便、快速地共享信息
- 创建线程比创建进程通常要快 10 倍甚至更多
- 线程间是共享虚拟地址空间的,无需采用写时复制来复制内存,也无需复制页表。
线程之间共享与非共享资源

NPTL
<aside>
💡 NPTL(Native POSIX Thread Library),一个线程库,是 Linux 线程的一个新实现,它
克服了 LinuxThreads 的缺点,同时也符合 POSIX 的需求
</aside>

<aside>
💡
编译带有线程库的代码时必须加上参数 -pthread
</aside>
gcc prog.c -o prog -pthread
// 相当于以下命令:
gcc prog.c -o prog -l pthread