ordered-parallel-iterator

Crates.ioordered-parallel-iterator
lib.rsordered-parallel-iterator
version0.2.0
sourcesrc
created_at2019-03-09 09:40:30.72412
updated_at2024-05-09 18:38:24.188807
descriptionPerforms tasks in parallel returning completed tasks in order of appearance.
homepagehttps://github.com/kilork/ordered-parallel-iterator
repositoryhttps://github.com/kilork/ordered-parallel-iterator
max_upload_size
id119600
size12,517
Alexander Korolev (kilork)

documentation

README

ordered-parallel-iterator

This crate provides an iterator over task results which performs tasks in parallel returning completed tasks in order of source range iterator. It can be useful if you need to process some data in parallel but need to have results in the order of appearance (FIFO).

Legal

Dual-licensed under MIT or the UNLICENSE.

Installation

Add following dependency to your Cargo.toml:

[dependencies]
ordered-parallel-iterator = "0.2"

Usage

use ordered_parallel_iterator::OrderedParallelIterator;

fn run_me(x: usize) -> usize {
    x + 1
}

fn main() {
    for i in OrderedParallelIterator::new(|| 0..10, || run_me) {
        println!("Result from iterator: {}", i);
    }
}

In this example each run_me call will happen in own thread, but results will be returned sequentially as fast as first will be finished. Count of pending tasks running in parallel bind to count of CPU cores.

Commit count: 10

cargo fmt