CSAPP第十二章读书笔记

这一章讲了并行的三种机制:

[1]基于进程的并行:

这里写图片描述

[2]基于I/O多路复用的并行:

基本思路是使用select函数,使得内核挂起进程,只有某一个I/O或者多个I/O事件发生之后,才会将内核返回给应用程序。

这里写图片描述

[3]基于线程的并行:

这里写图片描述

在这里还引入了信号量和锁的机制,我们利用信号量进行对共享资源的保护:互斥。还可以利用信号量来调度共享资源,比如消费者,生产者,读-写这种模型。

利用缓冲区,我们可以将一个web服务器设计成生产者,消费者模型。其中主线程负责接受客户端的请求并且生成套结字,然后提前生成的各个线程则作为消费者等待着可能的套结字出现,一旦出现就取出来并且进行服务。这种模型避免了过多的线程,但是也达到了并行的目的。

[4]线程不安全的四种情况,主要有没有对共享变量加锁,跨越多个调用状态,调用了别的县城不安全的函数,返回静态变量指针。

[5]死锁,这是一个很麻烦的问题,因为竞争导致的死胡同。每一个线程都在等一个永远不可能出现的V操作。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值