CSAPP第十二章读书笔记
来源:互联网 发布:知乎 国开博裕和博裕 编辑:程序博客网 时间:2024/06/04 23:22
这一章讲了并行的三种机制:
[1]基于进程的并行:
[2]基于I/O多路复用的并行:
基本思路是使用select函数,使得内核挂起进程,只有某一个I/O或者多个I/O事件发生之后,才会将内核返回给应用程序。
[3]基于线程的并行:
在这里还引入了信号量和锁的机制,我们利用信号量进行对共享资源的保护:互斥。还可以利用信号量来调度共享资源,比如消费者,生产者,读-写这种模型。
利用缓冲区,我们可以将一个web服务器设计成生产者,消费者模型。其中主线程负责接受客户端的请求并且生成套结字,然后提前生成的各个线程则作为消费者等待着可能的套结字出现,一旦出现就取出来并且进行服务。这种模型避免了过多的线程,但是也达到了并行的目的。
[4]线程不安全的四种情况,主要有没有对共享变量加锁,跨越多个调用状态,调用了别的县城不安全的函数,返回静态变量指针。
[5]死锁,这是一个很麻烦的问题,因为竞争导致的死胡同。每一个线程都在等一个永远不可能出现的V操作。
0 0
- CSAPP第十二章读书笔记
- CSAPP读书笔记第二章:
- csapp第三章读书笔记
- CSAPP第四章读书笔记
- Csapp读书笔记:第五章
- CSAPP第八章:读书笔记
- [CSAPP笔记][第十二章并发编程]
- 读书笔记:CSAPP
- CSAPP读书笔记(一)
- Python读书笔记第十二章:异常
- c++primer第十二章读书笔记
- CSAPP读书笔记第六章(优化cache命中率)
- 【CSAPP】《深入理解计算机系统》读书笔记
- 《CSAPP》读书笔记:面向高速缓存编程
- csapp读书笔记-fork函数详解
- think in java第十二章读书笔记
- C++ Primer 之 读书笔记 第十二章
- c++ primer读书笔记-第十二章 类
- 如何使用fdisk命令进行分区
- Azkaban 2.5.0 job type 插件安装
- The requested resource (/) is not available
- Swift3 String.Index 字符串截取
- 编译作业——LR文法的语法分析器
- CSAPP第十二章读书笔记
- spring jdbc
- log4j 写入DB 是不存在单引号的问题的!大家不要被不知所以然的家伙骗!
- Android开发 四大组件是否运行在主线程中?
- memcpy和memmove的区别
- networkD3包
- Spring源码分析之ioc容器第二天之oC容器在Web容器中的启动
- 在ec2上部署spark-部署成功后无法启动
- hibernate初探之单向一对多映射