Linux-线程-009

1基本概念

1.1线程

线程:线程是一个轻量级的进程,位于进程空间内部,一个进程中可以创建多个线程

1.2进程与线程的区别

进程是操作系统资源分配的最小单元
线程是CPU进行任务调度的最小单元

1.3多进程和多线程的优缺点

1.3.1效率

多线程>多进程
多线程只需在同一进程空间内切换
多进程需要在不同的空间中切换

1.3.2通信

1.3.2.1通信
多线程>多进程
线程共享全局变量,可以通过全局变量实现数据通信
进程空间是独立的,没有共享空间,通信实现比较复杂
1.3.2.2通信实现
多进程>多线程
线程共享空间操作时会引发资源竞争
进程没有共享空间,不存在资源竞争的问题

1.3.3安全

多进程>多线程
一个进程异常不会影响其余进程空间
一个线程异常结束会导致进程异常结束,进程异常结束,该进程内所有线程任务均无法向下执行

2线程创建

线程独占栈空间
文本段,数据段和堆区空间与进程是共享的

2.1线程分离属性

线程结束后,自动回收线程空间

3线程调度

与进程调度是一样的
宏观并行,微观串行

3.1原子操作

CPU最小的一次不能被任务调度打断的操作称为原子操作

3.2线程互斥

3.2.1基本概念

3.2.2互斥锁

防止资源竞争

注意:
(1)互斥锁只能解决资源竞争问题,无法同步代码(没有先后执行的顺序)
3.2.2.1临界资源/临界区
(1)加锁解锁中间的代码称为临界资源、临界区
(2)同一时刻临界资源不能同时执行,只能执行其中一个临界资源代码
3.2.2.2死锁
1.概念:多线程操作互斥锁,导致多个线程均无法向下执行的状态称为死锁状态简称为死锁
2.死锁产生的四个必要条件:
(1)互斥条件
(2)不可剥夺条件
(3)请求保持
(4)循环等待
3.如何避免产生死锁
(1)【pthread_mutex_trylock】替代【pthread_mutex_lock】
(2)加锁顺序保持一致

3.3信号量

信号量是一种资源,可以被初始化、申请、释放、销毁

P操作:申请资源
V操作:释放资源

4线程消亡

与进程消亡是一样的
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值