NativeFinalizer抽象 最终

一种可以附加到 Dart 对象上的本地终结器。

附加 到 Dart 对象后,此终结器的本地回调将在 Dart 对象被垃圾回收或因其他原因变得不可访问后被调用。

回调将在对象变得不可访问时尽可能早地发生,并且可能在程序执行期间任何时候发生。最迟,当隔离组关闭时,此回调保证将对隔离组中所有仍附加有终结器的对象调用。

与来自 dart:coreFinalizer 相比,后者不保证会调用附加的回调,此本地终结器承诺在隔离组关闭之前,所有附加的终结器至少被调用一次,并且一旦对象被识别为不可访问,回调就会尽可能快地被调用。

请注意,隔离组不一定保证会正常关闭,因为整个进程可能会崩溃或被像 exit 这样的函数突然终止。这意味着 NativeFinalizer 不能依赖于在程序退出时运行操作。

当回调是 Dart 函数而不是本地函数时,请使用 Finalizer

本地终结器可以用于关闭本地资源。请参阅以下示例。

/// [Database] enables interacting with the native database.
///
/// After [close] is called, cannot be used to [query].
///
/// If a [Database] is garbage collected, it is automatically closed by
/// means of a native finalizer. Prefer closing manually for timely
/// release of native resources.
///
/// Note this class is incomplete and for illustration purposes only.
class Database implements Finalizable {
  /// The native finalizer runs [_closeDatabasePointer] on [_nativeDatabase]
  /// if the object is garbage collected.
  ///
  /// Keeps the finalizer itself reachable, otherwise it might be disposed
  /// before the finalizer callback gets a chance to run.
  static final _finalizer =
      NativeFinalizer(_nativeDatabaseBindings.closeDatabaseAddress.cast());

  /// The native resource.
  ///
  /// Should be closed exactly once with [_closeDatabase] or
  /// [_closeDatabasePointer].
  Pointer<_NativeDatabase> _nativeDatabase;

  /// Used to prevent double close and usage after close.
  bool _closed = false;

  Database._(this._nativeDatabase);

  /// Open a database.
  factory Database.open() {
    final nativeDatabase = _nativeDatabaseBindings.openDatabase();
    final database = Database._(nativeDatabase);
    _finalizer.attach(database, nativeDatabase.cast(), detach: database);
    return database;
  }

  /// Closes this database.
  ///
  /// This database cannot be used anymore after it is closed.
  void close() {
    if (_closed) {
      return;
    }
    _closed = true;
    _finalizer.detach(this);
    _nativeDatabaseBindings.closeDatabase(_nativeDatabase);
  }

  /// Query the database.
  ///
  /// The database should not have been closed.
  void query() {
    if (_closed) {
      throw StateError('The database has been closed.');
    }

    // Query the database.
  }
}

final _nativeDatabaseBindings = _NativeDatabaseLib(DynamicLibrary.process());

// The following classes are typically generated with `package:ffigen`.
// Use `symbol-address` to expose the address of the close function.
class _NativeDatabaseLib {
  final DynamicLibrary _library;

  _NativeDatabaseLib(this._library);

  late final openDatabase = _library.lookupFunction<
      Pointer<_NativeDatabase> Function(),
      Pointer<_NativeDatabase> Function()>('OpenDatabase');
  late final closeDatabaseAddress =
      _library.lookup<NativeFunction<Void Function(Pointer<_NativeDatabase>)>>(
          'CloseDatabase');
  late final closeDatabase = closeDatabaseAddress
      .asFunction<void Function(Pointer<_NativeDatabase>)>();
}

final class _NativeDatabase extends Opaque {}
注解
  • @Since('2.17')

构造函数

NativeFinalizer(Pointer<NativeFinalizerFunction> callback)
使用给定的终结器回调创建一个终结器。
工厂

属性

hashCode int
此对象的哈希码。
no setterinherited
runtimeType Type
对象运行时类型的表示。
no setterinherited

方法

attach(Finalizable value, Pointer<Void> token, {Object? detach, int? externalSize}) → void
将此终结器附加到 value
detach(Object detach) → void
从使用 detach 附加的值中分离此终结器。
noSuchMethod(Invocation invocation) → dynamic
当访问不存在的方法或属性时调用。
继承
toString() String
此对象的字符串表示。
继承

操作符

operator ==(Object other) bool
相等操作符。
继承