zoukankan      html  css  js  c++  java
  • FCB CCB FileObject

    CCB  ContextControlBlock  是存Private信息的,这个FO的特殊信息

    FCB  FileControlBlock          是存全局信息的

    FO    FileObject                   代表一个文件打开实例

    之间关系:

    FO  与  CCB  是1:1的

    即一个FO有一个CCB根着

    FCB 与 CCB 是1:n的 (n >= 1)

    即一个FCB可能有n个CCB和它关联.

    FO->FsContext2指向CCB

    FO->FsContext指向CommFCB



    /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    FCB
     

        文件卷中的对象即磁盘上的对象,只要是打开着的,就在内存中有个“文件控制块”即FCB作为其代表。FCB代表着文件卷的目标对象(不一定是文件),而文件对象FILE_OBJECT结构则代表着这个目标对象的一次打开,或者说代表着这个目标对象与某个进程的一个连接。一个目标对象最多只有一个FCB,如果没有打开就没有FCB,但是却可以有多个文件对象,因为可以被多次打开。

        可想而知,文件对象中一定有指针指向目标对象的FCB。DeviceObject指向目标对象所在的设备即磁盘设备。指针FsContext(驱动程序为文件对象维护的状态信息)用来指向代表着目标对象的FCB。对于FAT文件系统而言这是一个VFATFCB数据结构。另一个指针指向FsContext2,就磁盘文件和目录来说,则用来指向一个“上下文控制块”即CCB。

        目标对象的每次打开都有个文件对象即FILE_OBJECT结构作为代表,同时又有个CCB。不过有时候CCB不是必要的。数据结构“文件参数块”VPB把抽象意义上的“文件卷”更物理意义上的磁盘联系在一起了。VPB中有两个指针,一个是DeviceObject,他指向代表着文件卷的设备对象,就是相应FSD所创建的设备对象。这决定了文件卷中的信息时如何组织的;另一个指针是RealDevice,它指向代表着具体(逻辑)磁盘的设备对象,这决定了信息是如何存储的。FILE_OBJECT结构中的指针指向一个VPB,这一方面表明目标卷存在于哪个逻辑磁盘上,另一方面表明这个磁盘承载着什么样的文件卷属于哪一种文件系统。

    /*
     尽管FsContext所指的FCB、DCB或VCB对象可以由文件系统驱动程序自行定义,
     但是,Windows的缓存管理器需要依赖于这些对象中的一个公共头部才可以工作,
     此公共头部称为//PFSRTL_COMMON_FCB_HEADER,如果文件系统驱动程序要使用缓存管理器提供的
     缓存功能,那么,他必须确保这些对象都以//PFSRTL_COMMON_FCB_HEADER作为头部成员

     */
       PFSRTL_COMMON_FCB_HEADER pFcb;

     /*
      FsContext域表示此文件对象所代表的实际对象的数据结构,如果文件对象代表一个磁盘目录,则它指向FCB
      FsContext2域指向CCB结构,代表文件对象的已打开实例。
      CCB:Context Control Block
      FCB针对每个文件而唯一存在,而CCB针对每一次打开文件而存在
      例如,两个应用程序共享访问同一个文件,他们的CCB不同,但它们的CCB中所指向的FCB是相同的,
      而且,CCB中记录了相应的应用程序正在操作该文件的偏移位置。在这种情况下,每个CCB关联不同的
      文件对象(FILE_OBJECT)

       */
       pFcb = (PFSRTL_COMMON_FCB_HEADER)pFileObject->FsContext;

    转自:http://blog.csdn.net/redchairman/article/details/7018063

  • 相关阅读:
    JavaScript ECMAScript版本介绍
    Webpack
    路由
    组件(重难点)
    npm包管理工具
    过滤器
    Vue实例生命周期
    数据双向绑定的原理
    MVC + MVVM
    vue事件修饰符
  • 原文地址:https://www.cnblogs.com/adylee/p/11171659.html
Copyright © 2011-2022 走看看