首页
/ Y-CRDT 项目中的观察者API优化方案解析

Y-CRDT 项目中的观察者API优化方案解析

2025-07-09 15:38:09作者:傅爽业Veleda

背景介绍

Y-CRDT 是一个基于 CRDT(冲突无复制数据类型)的 Rust 实现库,它提供了实时协作应用程序所需的数据同步功能。在版本 0.18 中,项目对观察者 API 进行了重大改进,解决了内存泄漏问题并为所有观察者类型提供了统一的 Subscription 接口。然而,这些改进也带来了一些新的挑战。

现有问题分析

当前观察者 API 存在两个主要问题:

  1. 函数签名限制:API 强制使用 Fn(&TransactionMut, T) 特征,这在某些场景下(如 Awareness API)显得特别笨重。

  2. 与 Yjs 兼容性问题:当前设计与 Yjs 的事件监听模式(on/off 风格 API)不兼容,这使得 ywasm 无法成为 Yjs 的直接替代品,也无法利用其插件生态。

解决方案设计

1. 自定义订阅键机制

核心思想是允许用户定义自己的订阅标识符(CallbackKey),而不是强制使用自动生成的序列号。这种设计与 Y-CRDT 中的 Origin 类型类似,支持多种形式的键值:

impl Observer<Func> {
  pub fn observe(&self, key: CallbackKey, callback: Arc<Func>);
  pub fn unobserve(&self, key: &CallbackKey);
}

这种设计在 WebAssembly 绑定中特别有用,可以直接使用 JavaScript 函数的 ABI 作为键值:

// 在 ywasm 中的实现示例
#[wasm_bindgen]
impl YMap {
  #[wasm_bindgen]
  fn observe(&self, callback: js_sys::Function) {
    let abi: u32 = callback.into_abi();
    let this: JsValue = self.into();
    self.subscribe(CallbackKey::from(abi), Arc::new(|txn, event| {
        // 回调处理逻辑
    })
  }
}

2. 保留现有 Subscription API

为了向后兼容,项目将保留现有的 Subscription 接口,但会重构其内部实现:

trait Unobserve {
  fn unobserve(&self, key: &CallbackKey);
}

#[repr(C)]
pub struct Subscription {
  observer: Weak<dyn Unobserve>
  key: CallbackKey
}

这种设计的关键点在于:

  • 所有观察者都实现 Unobserve 特征
  • Subscription 结构体弱引用观察者并持有回调键
  • Drop 实现自动处理取消订阅逻辑

技术优势

  1. 灵活性提升:开发者可以根据需要选择最适合的订阅管理方式,无论是使用自动生成的 Subscription 还是自定义的 CallbackKey。

  2. 兼容性增强:新的设计模式更接近 Yjs 的事件监听风格,为未来的兼容性铺平道路。

  3. 内存安全:通过 Weak 引用和自动取消订阅机制,继续保持良好的内存管理特性。

  4. 性能优化:自定义键值可以减少某些场景下的查找开销。

实际应用场景

这种改进后的观察者 API 特别适合以下场景:

  1. Web 前端集成:当通过 WASM 与 JavaScript 交互时,可以直接使用函数引用作为键值,实现高效的事件绑定。

  2. 插件系统开发:为未来可能的插件生态系统提供了更灵活的扩展点。

  3. 复杂事件处理:在需要精细控制事件订阅/取消订阅逻辑的应用程序中,自定义键值提供了更多控制权。

总结

Y-CRDT 对观察者 API 的这次迭代改进,在保持原有优点的同时,解决了 API 灵活性和生态系统兼容性的关键问题。通过引入自定义订阅键和重构 Subscription 实现,项目在以下方面取得了进展:

  • 提供了更符合不同使用习惯的 API 风格选择
  • 为与 Yjs 生态系统的潜在整合奠定了基础
  • 保持了 Rust 特有的内存安全特性
  • 为开发者提供了更多的控制权和灵活性

这种设计体现了对现有用户需求的尊重和对未来扩展性的前瞻性思考,是 CRDT 实现领域一个值得关注的技术演进。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
858
511
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
258
298
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
22
5