worker_manager 7.2.2 worker_manager: ^7.2.2 copied to clipboard
The worker_manager allows you to manage CPU-intensive calculations across isolates
Worker Manager #
Worker Manager is a powerful and easy-to-use library that helps you efficiently manage CPU-intensive tasks in your Flutter applications. It offers several advantages over traditional async programming or the built-in compute method. Note that the functions you are passing should either be static methods, globally defined functions or lambdas to ensure they are accessible from other isolates.
New Feature - dynamicSpawn flag in init #
By using this flag, worker_manager changes its behavior regarding isolate management. If this flag is set to true, new isolates will be spawned only if necessary and killed when they are no longer needed.
Advantages #
Efficient Scheduling #
This library schedules CPU-intensive functions to avoid skipping frames or freezes in your Flutter application. It ensures that your app runs smoothly, even when dealing with heavy computations.
Reusable Isolates #
Unlike the compute method, which always creates a new Dart isolate, Worker Manager reuses existing isolates. This approach is more efficient and prevents overloading the CPU. When resources are not freed up, using the compute method may cause freezes and skipped frames.
Cancelable Tasks #
Worker Manager provides a cancellation functionality through the Cancelable class and its cancel
method. This feature allows developers to free up resources when they are no longer needed, improving the app's performance and responsiveness.
Gentle Cancellation #
In addition to the standard cancellation method, Worker Manager offers a more gentle approach to cancellation. This new feature, executeGentle
, does not immediately terminate the Dart isolate but instead provides a lambda function that can be called periodically within the task to check if it should be cancelled. This allows tasks to clean up and terminate gracefully.
Inter-Isolate Communication #
The library supports communication between isolates with the executeWithPort
method. This feature enables sending progress messages or other updates between isolates, providing more control over your tasks.
Gentle Cancellation with Port #
The executeGentleWithPort
method is another valuable feature of Worker Manager that combines gentle cancellation and inter-isolate communication. It accepts two arguments: a port for inter-isolate communication and a getter function isCancelled
for gentle cancellation. This offers more flexibility and control, allowing tasks to communicate with other isolates while also providing an opportunity for graceful termination.
Usage #
Execute the task #
Cancelable<ResultType> cancelable = workerManager.execute<ResultType>(
() async {
// Your CPU-intensive function here
},
priority: WorkPriority.immediately,
);
Execute a Task with Gentle Cancellation #
Cancelable<ResultType> cancelable = workerManager.executeGentle<ResultType>(
(isCanceled) async {
while (!isCanceled()) {
// Your CPU-intensive function here
// Check isCanceled() periodically to decide whether to continue or break the loop
}
},
priority: WorkPriority.immediately,
);
Execute a Task with Inter-Isolate Communication #
Cancelable<ResultType> cancelable = workerManager.executeWithPort<ResultType, MessageType>(
(SendPort sendPort) async {
// Your CPU-intensive function here
// Use sendPort.send(message) to communicate with the main isolate
},
onMessage: (MessageType message) {
// Handle the received message in the main isolate
},
);
Execute a Task with Gentle Cancellation and Inter-Isolate Communication #
Cancelable<ResultType> cancelable = workerManager.executeGentleWithPort<ResultType, MessageType>(
(SendPort sendPort, IsCanceled isCanceled) async {
while (!isCanceled()) {
// Your CPU-intensive function here
// Use sendPort.send(message) to communicate with the main isolate
// Check isCanceled() periodically to decide whether to continue or break the loop
}
},
onMessage: (MessageType message) {
// Handle the received message in the main isolate
},
priority: WorkPriority.immediately,
);
Cancel a Task #
cancelable.cancel();
Dispose Worker Manager #
await workerManager.dispose();
Notice #
Before isolates support in wasm, implementation of execution of task same as compute method from foundation
Conclusion #
By using Worker Manager, you can enjoy the benefits of efficient task scheduling, reusable isolates, cancellable tasks, and inter-isolate communication. It provides a clear advantage over traditional async programming and the built-in compute method, ensuring that your Flutter applications remain performant and responsive even when handling CPU-intensive tasks. The additional executeGentleWithPort
feature provides both gentle cancellation and inter-isolate communication for your tasks, offering further control and efficiency.