widows如何执行I/O操作

     构造调用一个FileStream对象打开一个磁盘文件-----FileStream.Read方法从文件中读取数据(此时线程从托管代码转为本地/用户模式代码)----Read在内部调用win32ReadFile函数-----ReadFile分配一个小的数据结构(I/O请求包,简称IRP)----IRP请求结构初始化(包括:一个文件句柄,文件一个偏移量,一个byte[]数组地址,要传输的字节数,以及其他常规性内容)------初始化后ReadFile将线程从本地/用户模式代码转变为本地/内核模式代码,向内核传递IRP数据结构,调用windows内核-----windows内核根据IRP设备句柄windows内核知道I/O操作需要传送给哪些硬件设备------windows将IRP送给对应的设备驱动程序的IRP队列(每个驱动维护这自己的IRP队列)-------IRP到达的时候设备驱动程序将IRP信息传递给物理硬件设备上的电路板--完成

如果工作项被送入线程池的速度比一个线程处理它们的速度快,那么线程池可以创建额外的线程。例如,四核处理器,四个客户端请求可以同时在4个线程上同时运行。而且没有上下文切换。

线程池通过判断CPU是否饱和,来决定是否创建新的线程。

“I/O完成端口”(I/OCompletion Port):CLR在初始化的时候创建一个I/O完成端口,当打开硬件设备的时候,设备科绑定到I/O完成端口。驱动程序便知道将完成IRP送到哪个队列中。
     CLR没开始一次垃圾回收,CLR必须挂起进程中所有的线程。以保证垃圾回收速度变快。CLR必须遍历所有线程的栈来查找根(Root).

调试应用程序,遇到断点也会挂起调试程序中所有的线程。

CLR的异步编程模块(APM     Asychronous Programming Model)

       异步方式执行I/O操作,可以执行BeginXXX方法。所有的BeginXxx方法都返回一个实现了System.IAsyncResult接口的对象。调用BeginXxx方法时,会构造一个对象惟一来表示I/O请求,并将请求加入Windwos设备驱动程序的队列,然后返回对IAsyncResult对象的一个引用。

异步操作方式以EndXxx调用开始。在EndXxx和BeginXxx方法之间,只执行计算限制工作。I/O操作这些方法的“边界”处执行,所以线程永远不会阻塞。在每个方法之后,线程回到线程池中。等待处理网络响应。

AsyncEnumerator类

      APM编程模型缺陷:1.代码分解多个回调方法 2.不能使用实参和局部变量 3.不能再另一个地方结束构造 4.很难实现其他功能

AsynEnumerator利用了C#迭代器语言功能解决上面问题。

应用程序及其线程处理模型

      .netFramework支持不同的应程序模型。每个应用程序模型都可能引入自己的线程处理模型。

控制台应用程序和Windows服务没有引入任何种类线程处理模型。

GUI应用程序(windows窗体,wpf silverlight)引入一个线程处理模型。创建窗口线程是唯一能对那个窗口进行更新的线程。GUI线程是需要异步操作(鼠标,按键等)当异步完成时用一个线程池线程完成,而线程池线程不能负责显示更新过的UI。

SynchronizationContext类

SynchronizationContex派生对象负责将一个应用程序模型连接到他的线程处理模型。windows窗体应用程序,wpf和silverlight程序的GUI线程有一个和他关联SynchronizationContext派生对象。为了获取该对象的引用,可以让GUI查询SynchronizationContext的current属性,然后该对象引用保存到一个共享变量中。当一个线程池线程需要让GUI线程更新UI时,可以让引用保存的SynchronizationContext派生对象通过post方法传递GUI线程调用的方法。

APM注意事项

在 没有线程池的前提下使用APM

总是调用EndXxx方法而且只调用一次

调用EndXxx方法时总是用相同的对象

为BeginXxx和EndXxx方法使用ref,out,params实参

不能取消异步I/O限制操作

内存消耗

有的I/0操作必须同步完成

FileSteram特有的问题

I/O请求优先级

     暂时的版本只能通过P/Invoke本地win32函数方式制定I/O优先级

将IAsyncResultAPM转换为Task

基于事件的异步模式(EAP)

        EAP(Event-based Asynchronous Pattern)有点在于捅VS UI  设计器进行了很好的集成(winform的双击关联事件)。

将EAP转换为Task

APM和EAP对比

编程模型的沼泽

Clr Via C#读书笔记---I/O限制的异步操作的更多相关文章

  1. CLR via C# 读书笔记-27.计算限制的异步操作(上篇)

    前言 学习这件事情是一个习惯,不能停...另外这篇已经看过两个月过去,但觉得有些事情不总结跟没做没啥区别,遂记下此文 1.CLR线程池基础 2.ThreadPool的简单使用练习 3.执行上下文 4. ...

  2. CLR Via CSharp读书笔记(26) - 计算限制的异步操作

    执行上下文: 执行上下文包括安全设置(压缩栈.Thread的Principal属性和Windows身份),宿主设置(System.Threading.HostExecutionContextManag ...

  3. 《CLR via C#》读书笔记 之 计算限制的异步操作

    <CLR via C#>读书笔记 之 计算限制的异步操作 2014-07-06 26.1 CLR线程池基础 返回 如25章所述,创建和销毁线程是一个比较昂贵的操作: 太多的线程也会浪费内存 ...

  4. CLR via C# 读书笔记---常量、字段、方法和参数

    常量 常量是值从不变化的符号.定义常量符号时,它的值必须能在编译时确定.确定后,编译器将唱两只保存在程序集元数据中.使用const关键字声明常量.由于常量值从不变化,所以常量总是被视为类型定义的一部分 ...

  5. Clr Via C#读书笔记---计算限制的异步操作

    线程池基础 1,线程的创建和销毁是一个昂贵的操作,线程调度以及上下文切换耗费时间和内存资源. 2,线程池是一个线程集合,供应你的用程序使用. 3,每个CLR有一个自己的线程池,线程池由CLR控制的所有 ...

  6. Clr Via C#读书笔记---CLR寄宿和应用程序域

    #1 CLR寄宿: 开发CLR时,Microsoft实际是将他实现成包含在一个dll中的COM服务器.Microsoft为CLR定义了一个标准的COM接口,并为该接口和COM服务器分配了GUID.安装 ...

  7. Clr Via C#读书笔记---程序集的加载和反射

    #1 加载程序集 Assembly.Load: public class Assembly { public static Assembly Load(AssemblyName assemblyRef ...

  8. Clr Via C#读书笔记---垃圾回收机制

    #1 垃圾回收平台的基本工作原理: 访问一个资源所需的具体步骤: 1)调用IL指令newobj,为代表资源的类型分配内存.在C#中使用new操作符,编译器就会自动生成该指令.2)初始化内存,设置资源的 ...

  9. Clr Via C#读书笔记---线程基础

    趣闻:我是一个线程:http://kb.cnblogs.com/page/542462/ 进程与线程 进程:应用程序的一个实例使用的资源的集合.每个进程都被赋予了一个虚拟地址空间. 线程:对CPU进行 ...

随机推荐

  1. 使用EasyBCD完美实现Windows7与Linux双系统

    在Linux横行的时代,不玩Linux简直对不起它的流行,但又不能不用Windows,还要干活,还要工作啊,最重要的是:还要娱乐啊!! 废话不多说,直接进入主题! 1.下载EasyBCD,这个软件可以 ...

  2. 跟着百度学PHP[3]-PHP中结构嵌套之循环结构与条件结构嵌套

    任务 有个学生数组存储了学号和姓名,我们需要查找学号为"2014"的学生姓名,这时候我们就需要遍历该数组,并判定学号是否为"201 <?php $student = ...

  3. Laplacian matrix 从拉普拉斯矩阵到谱聚类

    谱聚类步骤 第一步:数据准备,生成图的邻接矩阵: 第二步:归一化普拉斯矩阵: 第三步:生成最小的k个特征值和对应的特征向量: 第四步:将特征向量kmeans聚类(少量的特征向量):

  4. backbone & django csrf_token的问题

    由于这个加入了token的验证,因此在backbone调用Model/Collection的save时会失败,错误403.(这里不讨论劫持重发的问题) 解决方案是:修改xmlHttpRequest的h ...

  5. postgresql 函数&存储过程 ; 递归查询

    函数:http://my.oschina.net/Kenyon/blog/108303 紧接上述,补充一下: 输入/输出参数的函数demo(输入作为变量影响sql结果,输出作为结果返回) create ...

  6. c# winform UI + python底层的一点尝试

    鉴于python做winform之类的UI比较弱.于是想结合C#的winform 和 python的底层开发(windows平台). 尝试做了一个RSS阅读器.在这里:http://download. ...

  7. JS添加删除DIV

    function addDiv(w,h){     //如果原来有“divCell”这个图层,先删除这个图层    deleteDiv();    //创建一个div       var my = d ...

  8. Google Code Jam 2015 R1C B

    题意:给出一个键盘,按键都是大写字母.给出一个目标单词和一个长度L.最大值或者最大长度都是100.现在随机按键盘,每个按键的概率相同. 敲击出一个长度为L的序列.求该序列中目标单词最多可能出现几次,期 ...

  9. UIScrollView 的 delaysContentTouches

    UIScrollView 的一段说明: Because a scroll view has no scroll bars, it must know whether a touch signals a ...

  10. WdatePicker组件不显示

    突然发现时间组件不显示了,以为是浏览器的问题.在本地服务器测试了一下发现一切正常. 怀疑是前段时间中毒引起的,用工具比对了一下WdatePicker的文件包,发现My97DatePicker.htm这 ...