news 2026/4/29 0:13:47

cfapi 入门实战(四):OnFetchData 与 CfExecute:真正的执行入口

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
cfapi 入门实战(四):OnFetchData 与 CfExecute:真正的执行入口

在 CFAPI 的学习过程中,大多数人会很快接触到
CF_CALLBACK_TYPE_FETCH_DATA → OnFetchData
却长期搞不清一个核心问题:

OnFetchData 到底是谁执行的?

答案并不在你的代码里,而在一个被 CFAPI 隐藏起来的执行入口

CfExecute

一、先给结论(重要)

CFAPI 并不是“事件回调模型”,而是“系统驱动执行模型”。

  • 你只负责:

    • 注册 SyncRoot

    • 注册 Callback

  • 真正执行 Cloud Files 逻辑的入口是 CfExecute

  • OnFetchData 只是 CfExecute 分发出来的一个执行分支


二、CFAPI 的真实执行链路

文件访问到 OnFetchData 的完整路径

用户 / 应用访问文件 ↓ I/O Manager ↓ NTFS + Filter Manager ↓ cldflt.sys(Cloud Files Filter) ↓ CFAPI Runtime ↓ CfExecute ←【执行入口】 ↓ CF_CALLBACK_TYPE_FETCH_DATA ↓ OnFetchData

关键点:

  • ❌ OnFetchData不是你主动调用

  • ❌ 也不是 CreateFile 直接调用

  • 是 CfExecute 在执行 Cloud Files 语义时分发


三、CfExecute 是什么?为什么你看不到?

1. CfExecute 的角色

CfExecute 是 CFAPI 内部的“执行调度器”,负责:

  • 判定当前文件操作是否属于 Cloud Files

  • 选择合适的 Callback 类型

  • 调度并发与线程

  • 驱动整个占位符生命周期

2. 为什么 API 中没有 CfExecute?

因为:

  • 不属于 Provider 可控范围

  • 由系统在内核 / Runtime 层自动调用

  • 目的是保证文件系统一致性

你只需要通过:

CfConnectSyncRoot(...)

把自己“挂”到 CfExecute 上。

四、CfConnectSyncRoot 做了什么(本质)

CfConnectSyncRoot( SyncRootPath, CallbackMappings, ProviderContext, Flags, out ConnectionKey );

这一步的本质是:

  • 告诉 CFAPI Runtime:

    • “这个路径下的 Cloud Files 由我负责”

    • “当 CfExecute 执行到这里时,用这些 Callback”

没有这一步:

  • CfExecute 不会路由到你

  • OnFetchData 永远不会被调用

五、OnFetchData 什么时候会被 CfExecute 分发?

触发条件(同时满足)

  1. 文件是占位符(Placeholder)

  2. 文件当前状态需要内容数据

  3. 当前操作触及文件内容

满足后:

CfExecute → CF_CALLBACK_TYPE_FETCH_DATA → OnFetchData

常见触发行为

行为是否触发
ReadFile
Copy 文件
Explorer 打开
只读取属性
FILE_FLAG_OPEN_REPARSE_POINT
完整 Hydrated 文件

六、为什么“CreateFile 看起来触发了 OnFetchData”?

这是你之前反复遇到的问题,本质原因在 CfExecute。

原因拆解

  • CreateFile本身 ≠ Fetch

  • 但:

    • Explorer 会在 CreateFile 后做探测性 Read

    • 某些 Flag 会触发缓冲读取

  • CfExecute 判断:需要内容数据

  • → 分发 FetchData

所以现象是:

你以为是 CreateFile 触发,实际上是后续的隐式 Read 触发


七、OnFetchData 的执行语义(非常关键)

OnFetchData 并不等于“下载文件”

它的真实语义是:

“请提供 [Offset, Offset + Length) 这段数据”

因此:

  • Fetch 可能:

    • 多次

    • 不连续

    • 并发

  • Offset 可能不是 0

  • Length 不等于文件大小


八、OnFetchData 的标准处理闭环

正确的执行顺序

OnFetchData 被 CfExecute 分发 ↓ 解析 Offset / Length ↓ 从云端或缓存读取对应数据 ↓ CfWriteFile 写入指定 Offset ↓ CfCompleteFetchData(HRESULT.S_OK)

如果漏掉最后一步?

  • CfExecute 认为请求未完成

  • 文件访问卡死

  • Explorer 无响应


九、CfExecute 下的并发与线程模型

你必须接受的事实

  • CfExecute:

    • 多线程

    • 并发

    • 可重入

  • 同一文件:

    • 可能多个 Fetch 同时发生

Provider 的要求

  • OnFetchData:

    • 必须线程安全

    • 不要长时间阻塞

    • 支持 Range 下载


十、统一理解(工程师视角)

CfExecute 是 CFAPI 的“隐形主循环”,
OnFetchData 是它在执行“文件内容请求”时分发出来的一个回调。

你不是在“监听事件”,
而是在参与 Windows 文件系统的一次执行流程


十一、一句话总结

  • CfExecute 决定“什么时候执行”

  • OnFetchData 决定“如何给数据”

  • Provider 只是被动参与系统执行

只要你用这个模型去理解 CFAPI,
你前面遇到的Fetch 乱触发、句柄问题、卡死问题,都会自然对上。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 1:46:57

6、Linux与Windows集成:通信、安全与办公应用全解析

Linux与Windows集成:通信、安全与办公应用全解析 在当今数字化的时代,Linux和Windows操作系统在不同场景下都有着广泛的应用。为了更好地实现信息交流和资源共享,将两者进行集成变得尤为重要。本文将详细介绍Linux和Windows集成过程中的通信工具、网络安全以及办公应用等方…

作者头像 李华
网站建设 2026/4/25 8:26:08

FP16与INT8精度下Qwen3-14B性能变化实测

FP16与INT8精度下Qwen3-14B性能变化实测 在当前大模型加速落地的浪潮中,越来越多企业开始尝试将像 Qwen3-14B 这样的百亿参数级语言模型部署到私有环境中。但随之而来的问题也愈发突出:如何在有限的GPU资源下跑得动?如何让推理又快又稳&#…

作者头像 李华
网站建设 2026/4/26 6:44:40

12、Linux与Windows集成指南

Linux与Windows集成指南 1. 密码加密支持情况 Windows 95、OSr2、Windows 98 以及带有 Service Pack 3 或更高版本的 Windows NT 默认支持加密密码。而 DOS 和较旧版本的 Windows 在不进行升级的情况下不支持加密密码。 2. 向现有网络添加 Samba 服务器 网络设置获取 :将…

作者头像 李华
网站建设 2026/4/23 13:33:33

网站打不开、响应慢,可能是DNS解析出现了问题!

在网站运营过程中,“响应慢”“打不开”是最影响用户体验和业务转化的致命问题。多数运营者会第一时间排查服务器负载、带宽占用或程序代码,但往往忽略了一个关键环节——DNS解析。 作为互联网访问的“导航系统”,DNS解析的稳定性直接决定用…

作者头像 李华
网站建设 2026/4/23 12:10:36

Anaconda配置PyTorch环境的最佳实践:结合CUDA加速库

Anaconda配置PyTorch环境的最佳实践:结合CUDA加速库 在深度学习项目中,一个常见但令人沮丧的场景是:你精心编写了模型代码,满怀期待地启动训练,结果发现GPU利用率始终为0——程序仍在用CPU慢吞吞地跑。这种“明明有车…

作者头像 李华
网站建设 2026/4/23 13:30:20

大表(千万级)查询 / 维护该怎么办?

可以看另一篇博客-sql调优 总起:体现架构思维 首先表明态度,避免直接陷入技术细节: “在项目中处理千万级大表时,我理解这不是一个单纯的SQL优化问题,而是一个需要从应用架构、数据架构和运维架构三个维度综合考量的…

作者头像 李华