Flutter 中的异步事件处理之StreamController源码解析(二)

StreamController

同步流、异步流

scss 复制代码
/// A controller with a [stream] that supports only one single subscriber.
///
/// If [sync] is true, the returned stream controller is a
/// [SynchronousStreamController], and must be used with the care
/// and attention necessary to not break the [Stream] contract. If in doubt,
/// use the non-sync version.
///
/// Using an asynchronous controller will never give the wrong
/// behavior, but using a synchronous controller incorrectly can cause
/// otherwise correct programs to break.
///
/// A synchronous controller is only intended for optimizing event
/// propagation when one asynchronous event immediately triggers another.
/// It should not be used unless the calls to [add] or [addError]
/// are guaranteed to occur in places where it won't break `Stream` invariants.
///
/// Use synchronous controllers only to forward (potentially transformed)
/// events from another stream or a future.
///
/// A Stream should be inert until a subscriber starts listening on it (using
/// the [onListen] callback to start producing events). Streams should not
/// leak resources (like websockets) when no user ever listens on the stream.
///
/// The controller buffers all incoming events until a subscriber is
/// registered, but this feature should only be used in rare circumstances.
///
/// The [onPause] function is called when the stream becomes
/// paused. [onResume] is called when the stream resumed.
///
/// The [onListen] callback is called when the stream
/// receives its listener and [onCancel] when the listener ends
/// its subscription. If [onCancel] needs to perform an asynchronous operation,
/// [onCancel] should return a future that completes when the cancel operation
/// is done.
///
/// If the stream is canceled before the controller needs data the
/// [onResume] call might not be executed.
factory StreamController(
    {void onListen()?,
    void onPause()?,
    void onResume()?,
    FutureOr<void> onCancel()?,
    bool sync = false}) {
  return sync
      ? _SyncStreamController<T>(onListen, onPause, onResume, onCancel)
      : _AsyncStreamController<T>(onListen, onPause, onResume, onCancel);
}
  • 一个带有 stream 的控制器,仅支持单个订阅者。
  • 如果 sync 为 true,返回的流控制器是一个 SynchronousStreamController,必须小心谨慎地使用,以确保不破坏 Stream 契约。如果有疑虑,应使用非同步版本。
  • 使用异步控制器永远不会导致错误行为,但不正确地使用同步控制器可能会导致 其他正确的程序出现问题。
  • 同步控制器仅用于在一个异步事件立即触发另一个事件的情况下优化事件传播。
  • 除非可以确保 addaddError 调用发生在不会破坏 Stream 不变式的地方,否则不应使用同步控制器。
  • 只有在将(可能经过转换)事件从另一个流或 Future 转发时,才应使用同步控制器。
  • 直到有订阅者开始监听流(使用 onListen 回调来开始生成事件)之前,流应该是不活动的。流不应在没有用户监听流的情况下泄露资源(例如 WebSockets)。
  • 控制器会缓冲所有传入的事件,直到注册订阅者,但这个功能只应在极少数情况下使用。
  • 当流暂停时,onPause 函数将被调用。当流恢复时,onResume 将被调用。
  • 当流接收到其监听器时,将调用 onListen 回调,并在监听器结束其订阅时调用 onCancel
  • 如果 onCancel 需要执行异步操作,onCancel 应该返回一个在取消操作完成时完成的 future。
  • 如果流在控制器需要数据之前被取消,onResume 调用可能不会执行。
  • sync:是否创建同步控制器,默认为 false。
相关推荐
yuanyxh2 小时前
Mac 软件推荐
前端·javascript·程序员
万少2 小时前
AtomCode开发微信小程序《谁去呀》 全流程
前端·javascript·后端
某人辛木2 小时前
Web自动化测试
前端·python·pycharm·pytest
Kagol3 小时前
Superpowers GSD gstack AgentSkills深度测评
前端·人工智能
excel4 小时前
JavaScript 字符串与模板字面量:从表象到本质理解
前端
京东云开发者4 小时前
当AI成为导演-如何用AI创作动漫短剧
前端
李白的天不白4 小时前
使用 SmartAdmin 进行前后端开发
java·前端
乘风gg5 小时前
🤡PUA AI Coding 工具 的 10 条终极语录
前端·ai编程·claude
学Linux的语莫5 小时前
Vue 3 入门教程
前端·javascript·vue.js
怕浪猫5 小时前
第一章、Chrome DevTools Protocol (CDP) 详解
前端·javascript·chrome