linux进程与线程的区别
线程
LWP:light weight process
轻量级的进程,本质仍是进程(在Linux
环境下)
进程:独立地址空间,拥有PCB
线程:也有PCB
,但没有独立的地址空间(共享)
区别:在于是否共享地址空间。 独居(进程);合租(线程)。
Linux
下:
线程:最小的执行单位
进程:最小分配资源单位,可看成是只有一个线程的进程。
Linux
内核线程实现原理
类Unix
系统中,早期是没有“线程”概念的,80年代才引入,借助进程机制实现出了线程的概念。因此在这类系统中,进程和线程关系密切。
1. 轻量级进程(light-weight process
),也有PCB
,创建线程使用的底层函数和进程一样,都是clone
2. 从内核里看进程和线程是一样的,都有各自不同的PCB
,但是PCB
中指向内存资源的三级页表是相同的
3. 进程可以蜕变成线程
4. 线程可看做寄存器和栈的集合
5. 在linux
下,线程最是小的执行单位;进程是最小的分配资源单位
注意:
1. 察看LWP号:ps –Lf pid 查看指定线程的lwp号。
2. 线程号lwp是linux内核划分时间轮片给线程的依据。
3. 线程id是进程内部区分线程用的。
三级映射:进程PCB --> 页目录(可看成数组,首地址位于PCB中) --> 页表 --> 物理页面 --> 内存单元
进程与线程的区别:
- 对于进程来说,相同的地址(同一个虚拟地址)在不同的进程中,反复使用而不冲突。原因是他们虽虚拟址一样,但,页目录、页表、物理页面各不相同。相同的虚拟址,映射到不同的物理页面内存单元,最终访问不同的物理页面。
但!线程不同!两个线程具有各自独立的PCB
,但共享同一个页目录,也就共享同一个页表和物理页面。所以两个PCB
共享一个地址空间。 - 实际上,无论是创建进程的
fork
,还是创建线程的pthread_create
,底层实现都是调用同一个内核函数clone
。 - 如果复制对方的地址空间,那么就产出一个“进程”;如果共享对方的地址空间,就产生一个“线程”。
- 因此:
Linux
内核是不区分进程和线程的。只在用户层面上进行区分。所以,线程所有操作函数pthread_*
是库函数,而非系统调用。