You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
samples/isolate_example/README.md

48 lines
2.0 KiB

# Isolate Example
A sample application that demonstrate best practices when using [`isolates`](https://api.dartlang.org/stable/2.3.1/dart-isolate/Isolate-class.html).
## Goals
* Display the performance benefits of isolates when using them in the right situation.
* Show how to use the `compute` method for straightforward computations.
* Demonstrate how to initialize and use an isolate.
* Show the cost of moving data between isolates and provide alternatives.
## The important bits
### `performance_page.dart`
Compares running a large computation on the main isolate with running the same calculation
on a second isolate. When the main isolate is used, Flutter is unable to render new frames, and
the `SmoothAnimationWidget`'s animation freezes.
### `infinite_process_page.dart`
Creates an isolate used to run an infinite loop that sums batches of 100M randomly generated
numbers at a time. Users can start, terminate, pause, and resume the isolate, as well as modify
how the calculation is performed.
### `data_transfer_page.dart`
Demonstrates how expensive it is to move large amounts of data between isolates and a
better alternative to move data. This page creates an isolate that can add up a list of numbers
and gives users three options for how to provide it with input:
* Send values normally using a List
* Send the values using TransferableTypedData
* Generate the values on the second isolate, so no copying is necessary
Users can then compare the performance of each approach using the displayed timestamps.
## Questions/issues
If you have a general question about any of the techniques you see in
the sample, the best places to go are:
* [The FlutterDev Google Group](https://groups.google.com/forum/#!forum/flutter-dev)
* [The Flutter Gitter channel](https://gitter.im/flutter/flutter)
* [StackOverflow](https://stackoverflow.com/questions/tagged/flutter)
If you run into an issue with the sample itself, please file an issue
in the [main Flutter repo](https://github.com/flutter/flutter/issues).