linux 线程概述 线程与进程的区别
线程概述:
与进程(process)类似,线程(thread)是允许应用程序并发执行多个任务的一种机制。一个进程可以包含多个线程。同一个程序中的所有线程均会独立执行相同程序,且共享同一份全局内存区域,其中包括初始化数据段、未初始化数据段,以及堆内存段。(传统意义上的 UNIX 进程只是多线程程序的一个特例,该进程只包含一个线程)
进程是 CPU 分配资源的最小单位, 线程是操作系统调度执行的最小单位。
线程是轻量级的进程 (LWP: Light Weight Process),在 Linux 环境下 线程的本质仍是进程。
查看执行进程的 LWP号: ps - Lf pid
线程与进程的区别:
进程间的信息难以共享。由于除去只读代码段外,父子进程并未共享内存,因此必须采用一些进程间通信方式,在进程间进行信息交换。
调用 fork() 来创建进程的代价相对较高,即便利用写时复制技术,仍然需要复制诸如 内存页表 和 文件描述符表 之类的多种进程属性, 这意味着 fork() 调用在时间上的开销依然不菲。
线程之间能够方便、快速的共享信息。只需将数据复制到共享(全局或堆)变量中即可。
创建线程比创建进程通常要快10倍甚至更多。线程间的共享虚拟地址空间的,无需采用 写时复制来复制内存,也无需复制页表。
fork() 写的时候会复制新的虚拟地址空间,读时共享,但写的时候需要复制的时间。
而线程仅是在 栈空间和 .text(代码段) 分成多个线程的区域 其他位置共享不变。
栈空间:由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。
共享库:一个共享程序库就是一个共享函数库,应用程序可以在运行时连接到该程序库,而不是在编译时连接。在Windows中,共享程序库被称为动态链接库;
堆空间:一般由程序员分配释放。
bss段:通常是指用来存放程序中未初始化的或者初始化为0的全局变量和静态变量的一块内存区域。特点是可读写的,在程序执行之前BSS段会自动清0。
data段:存放程序中已初始化的全局变量的内存区域,属于静态内存分配。
text段:存放程序执行代码的内存区域。
线程之间共享和非共享资源:
NPTL: 发展介绍
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)