Linux多线程概述
概念
1.进程
进程是系统中程序执行和资源分配的基本单位。每个进程都有自己的数据段、代码段和堆栈段。
2.线程
线程是为了进一步减少处理器空转时间支持多处理器和减少上下文切换开销而生的。
线程是在共享内存空间中并行执行的多道执行路径,是一个更加接近执行体的概念,拥有独立的执行序列,是进程的基本调度单元,每个进程至少都有一个main线程。
线程与同进程中的其他线程共享进程空间{ 堆 代码 数据 文件描述符 信号等},只拥有自己的栈空间,大大减少了上下文切换的开销。
3.优缺点
- 线程执行开销小,占用的CPU少,线程之间的切换快,但不利于资源的管理和保护;
- 进程正相反。从可移植性来讲,多进程的可移植性要好些。
线程分类
按调度者分为 用户级线程 和 核心级线程
●用户级线程:主要解决上下文切换问题,调度算法和调度过程全部由用户决定,在运行时不需要特定的内核支持。缺点是无法发挥多处理器的优势
●核心级线程:允许不同进程中的线程按照同一相对优先调度方法调度,发挥多处理器的并发优势
现在大多数系统都采用用户级线程和核心级线程并存的方法。一个用户级线程可以对应一个或多个。
线程创建的Linux实现
Linux的线程是通过用户级的函数库实现的,一般采用pthread线程库实现线程的访问和控制。它用
第3方posix标准的pthread,具有良好的可移植性。编译的时候要在后面加上 -lpthread
相关问题
多进程与多线程的区别:
1、多进程每一个都有自己独立的进程地址空间,资源不共享,需要通过进程间通信;多线程是资源共享的,栈、堆、数据区、代码段有自己独立的线程控制表(在内核里)
2、进程崩溃不会影响其他进程,线程崩溃以后整个进程结束
3、进程启动速度慢于线程,线程切换速度快于进程