一种可以附加到 Dart 对象上的本地终结器。
当 附加 到 Dart 对象后,此终结器的本地回调将在 Dart 对象被垃圾回收或因其他原因变得不可访问后被调用。
回调将在对象变得不可访问时尽可能早地发生,并且可能在程序执行期间任何时候发生。最迟,当隔离组关闭时,此回调保证将对隔离组中所有仍附加有终结器的对象调用。
与来自 dart:core
的 Finalizer 相比,后者不保证会调用附加的回调,此本地终结器承诺在隔离组关闭之前,所有附加的终结器至少被调用一次,并且一旦对象被识别为不可访问,回调就会尽可能快地被调用。
请注意,隔离组不一定保证会正常关闭,因为整个进程可能会崩溃或被像 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< Object? detach, int? externalSize}) → voidVoid> token, { - 将此终结器附加到
value
。 -
detach(
Object detach) → void - 从使用 detach 附加的值中分离此终结器。
-
noSuchMethod(
Invocation invocation) → dynamic - 当访问不存在的方法或属性时调用。继承
-
toString(
) → String - 此对象的字符串表示。继承
操作符
-
operator ==(
Object other) → bool - 相等操作符。继承