【Linux学习小结】Linux多线程

Linux多线程概述

概念

1.进程

进程是系统中程序执行资源分配基本单位。每个进程都有自己的数据段、代码段和堆栈段。

2.线程

线程是为了进一步减少处理器空转时间支持多处理器和减少上下文切换开销而生的。
线程是在共享内存空间并行执行多道执行路径,是一个更加接近执行体的概念,拥有独立的执行序列,是进程的基本调度单元,每个进程至少都有一个main线程
线程与同进程中的其他线程共享进程空间{ 堆 代码 数据 文件描述符 信号等},只拥有自己的栈空间,大大减少了上下文切换的开销。

3.优缺点

  • 线程执行开销小占用的CPU少,线程之间的切换快,但不利于资源的管理和保护;
  • 进程正相反。从可移植性来讲,多进程的可移植性要好些。

线程分类

按调度者分为 用户级线程核心级线程

用户级线程:主要解决上下文切换问题,调度算法和调度过程全部由用户决定,在运行时不需要特定的内核支持。缺点是无法发挥多处理器的优势
核心级线程:允许不同进程中的线程按照同一相对优先调度方法调度,发挥多处理器的并发优势

现在大多数系统都采用用户级线程和核心级线程并存的方法。一个用户级线程可以对应一个或多个。

线程创建的Linux实现

Linux的线程是通过用户级的函数库实现的,一般采用pthread线程库实现线程的访问和控制。它用
第3方posix标准的pthread,具有良好的可移植性。编译的时候要在后面加上 -lpthread

请添加图片描述

相关问题

多进程与多线程的区别
1、多进程每一个都有自己独立的进程地址空间,资源不共享,需要通过进程间通信;多线程是资源共享的,栈、堆、数据区、代码段有自己独立的线程控制表(在内核里)
2、进程崩溃不会影响其他进程,线程崩溃以后整个进程结束
3、进程启动速度慢于线程,线程切换速度快于进程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值