/parallel

Primary LanguageC++MIT LicenseMIT

Running isolate easily.

Features

Give more power to your app with multicore processing.

Getting started

    import 'dart:io';

    void main() {
        // run core dedicated isolates.
        Parallel.initialize(
            numberOfIsolates: Platform.numberOfProcessors -1, // minus one used for allocating to main isolate.
            maxConcurrentPerIsolate: 100, // limit to 100 execution per isolate
            onInitialization: () {
                // register your dependency injection
                // for example using GetIt.I.register...
            },
        );

        runApp(MyApp());
    }

Usage

Execute action in isolate.

final result = await Parallel.run((){
    // do your heavy task here.
});

Execute action in main isolate from worker isolate.

final result = await Parallel.run((){
    final data = await Parallel.runInMain((){
        // get your main data
    });

    print(data);
});

Additional information

WARNING: Since isolates are not sharing memory each other, you have to make sure the data that passed between isolates are not mutable.