Giter VIP home page Giter VIP logo

thread_utils's Introduction

thread_utils

Helpers for Multi-threading development

  • Producer/Consumer
Producer<String> producer = Producer.create(String.class, new Consumer<String>() {
    public void consume(String item) {
        System.out.println(Thread.currentThread().getId() + " : item = [" + item + "]");
    }
});

for (int i = 0; i < 10; i++){
    producer.submit("test_" + i);
}

producer.stop();
  • ParallelRunner

Builds on Producer/Consumer to provide an easy way to run multiple tasks in parallel. When all tasks complete, a callback is called.

private static class SampleRunnable implements Runnable{
    private int id = 0;

    public SampleRunnable(int id) {
        this.id = id;
    }

    @Override
    public void run() {
        System.out.println("run with id : " + id);
    }
}
ParallelRunner runner = ParallelRunner.builder().withThreads(3).build();
runner.start();

// async, method returns as soon as all tasks are submitted to execution, 
// but have not necessarily completed.
runner.run(new Runnable() {
                       @Override
                       public void run() {
                           System.out.println("onComplete");
                       }
                   },
                new SampleRunnable(1),
                new SampleRunnable(2),
                new SampleRunnable(3),
                new SampleRunnable(4)
        );

System.out.println("Maybe called before callback");

runner.stop();
ParallelRunner runner = ParallelRunner.builder().withThreads(3).build();
runner.start();

// without a callback
runner.runSync(
            new SampleRunnable(1),
            new SampleRunnable(2),
            new SampleRunnable(3),
            new SampleRunnable(4)
        );

System.out.println("called when all tasks complete");

runner.stop();

thread_utils's People

Contributors

joseerodrigues avatar

Stargazers

 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.