线程与进程优缺点,以及共享资源和非共享资源能讲明白吗

1. 什么是线程

线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。在 Unix System V 及 SunOS 中也被称为轻量进程(lightweight processes),但轻量进程更多指内核线程(kernel thread),而把用户线程(user thread)称为线程。


2. 线程和进程的关系

轻量级进程(light-weight process),也有 PCB,创建线程使用的底层函数和进程一 样,都是 clone;


从内核里看进程和线程是一样的,都有各自不同的 PCB,但是 PCB 中指向内存资源的三级页表是相同的;


进程可以蜕变成线程;


在美国人眼里,线程就是寄存器和栈;


在 linux 下,线程最是小的执行单位;进程是最小的分配资源单位查看 LWP 号




ps -Lf pid 
ps -eLf



3. 线程间共享资源

  1. 文件描述符表;
  2. 每种信号的处理方式;
  3. 当前工作目录;
  4. 用户 ID 和组 ID;
  5. 内存地址空间
Text 
data
bss
堆
共享库



4. 线程间非贡献资源

  1. 线程 id;
  2. 处理器现场和栈指针(内核栈);
  3. 独立的栈空间(用户空间栈);
  4. errno 变量;
  5. 信号屏蔽字;
  6. 调度优先级

5. 线程优缺点

优点:



  1. 提高程序的并发性;
  2. 开销小,不用重新分配内存;
  3. 通信和共享数据方便


缺点:



  1. 线程不稳定(库函数实现);
  2. 线程调试比较困难(gdb 支持不好);
  3. 线程无法使用 unix 经典事件,例如信号

6. pthread manpage

查看 manpage 关于 pthread 的函数




man -k pthread



Ubuntu 可以通过以下命令安装 man 命令:sudo apt-get install manpages-posix manpages-posix-dev


 0
 0
 分享
评论图片
评论