All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.vlingo.actors.SmallestMailboxRouter Maven / Gradle / Ivy

Go to download

Type safe Actor Model toolkit for reactive concurrency and resiliency using Java and other JVM languages.

There is a newer version: 1.7.5
Show newest version
// Copyright © 2012-2020 VLINGO LABS. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.

package io.vlingo.actors;
/**
 * SmallestMailboxRouter
 */
public class SmallestMailboxRouter

extends Router

{ public SmallestMailboxRouter(final RouterSpecification

specification) { super(specification); } /* @see io.vlingo.actors.Router#computeRouting() */ @Override protected Routing

computeRouting() { Routee

least = null; int leastCount = Integer.MAX_VALUE; for (Routee

routee : routees()) { int count = routee.pendingMessages(); if (count == 0) { least = routee; break; } else if (count < leastCount) { least = routee; leastCount = count; } } return Routing.with(least); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy