news 2026/5/23 23:09:31

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/5/23 6:10:44

豆包AI手机为何遭到全网“围剿”?大厂们到底在怕什么?

2025年12月,豆包AI手机的发布瞬间引爆了整个科技圈,媒体和社交平台上的讨论声浪几乎没有停歇。这款由豆包科技推出的手机不仅在功能上做出了许多创新,更是通过其革命性的人工智能系统,提出了一种全新的智能手机使用体验。然而&…

作者头像 李华
网站建设 2026/5/23 23:09:30

2025广东汽车应急电源供应商权威推荐榜单重磅发布

行业痛点分析当前汽车应急电源领域面临着诸多技术挑战。一方面,在极端温度环境下的性能表现不佳是一大难题。测试显示,传统汽车应急电源在低温 -20℃ 时,其启动成功率可能会下降至 30% 左右,而在高温 60℃ 环境中,电池…

作者头像 李华
网站建设 2026/5/22 13:06:55

AI产品经理:未来最赚钱的职位之一,揭秘其工作内容与高薪原因!

据统计,AI产品经理起薪普遍20-28K,比传统产品经理高出约一倍,人才缺口持续扩大 “我不是在训练模型,我是让AI为人所用。”一位来自头部互联网公司的AI产品经理这样描述他的工作。 随着ChatGPT、文心一言等大模型的爆发&#xff0…

作者头像 李华
网站建设 2026/5/21 6:09:27

多智能体系统构建指南——让AI像创业团队一样协作解决复杂问题!

简介 多智能体系统不是简单拼凑多个模型,而是通过分工、协作、竞争和组织方式,让AI智能体形成真正的团队关系,解决单一模型难以应对的复杂任务。该系统具有分布式探索、独立上下文和并行推理三大优势,智能体需具备自主性、反应性…

作者头像 李华
网站建设 2026/5/8 14:08:37

Qwen3-32B在数学推理任务上的表现超过Grok-1

Qwen3-32B为何能在数学推理上超越Grok-1? 在当前大模型竞争进入“深水区”的背景下,参数规模的军备竞赛逐渐让位于实际任务表现的精细比拼。人们不再满足于“能说会道”的通用对话模型,而是更关注其是否具备解决专业问题的能力——尤其是在数…

作者头像 李华
网站建设 2026/5/18 13:25:31

json.dumps() 的输出

json.dumps() 的输出可能不符合我们的阅读习惯——这时候就需要用到参数来“美化”它。二、参数 1:ensure_asciiFalse✅ 默认行为(不加这个参数):json.dumps({"城市": "东京"}) # 输出:{"\u…

作者头像 李华