Class OrderByMoveIndexBlockingQueue<Solution_>
- java.lang.Object
-
- org.optaplanner.core.impl.heuristic.thread.OrderByMoveIndexBlockingQueue<Solution_>
-
public class OrderByMoveIndexBlockingQueue<Solution_> extends Object
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classOrderByMoveIndexBlockingQueue.MoveResult<Solution_>
-
Constructor Summary
Constructors Constructor Description OrderByMoveIndexBlockingQueue(int capacity)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddExceptionThrown(int moveThreadIndex, Throwable throwable)This method is thread-safe.voidaddMove(int moveThreadIndex, int stepIndex, int moveIndex, Move<Solution_> move, Score score)This method is thread-safe.voidaddUndoableMove(int moveThreadIndex, int stepIndex, int moveIndex, Move<Solution_> move)This method is thread-safe.voidstartNextStep(int stepIndex)Not thread-safe.OrderByMoveIndexBlockingQueue.MoveResult<Solution_>take()Not thread-safe.
-
-
-
Method Detail
-
startNextStep
public void startNextStep(int stepIndex)
Not thread-safe. Can only be called from the solver thread.- Parameters:
stepIndex- at least 0
-
addUndoableMove
public void addUndoableMove(int moveThreadIndex, int stepIndex, int moveIndex, Move<Solution_> move)This method is thread-safe. It can be called from any move thread.- Parameters:
moveThreadIndex-0 <= moveThreadIndex < moveThreadCountstepIndex- at least 0moveIndex- at least 0move- never null- See Also:
BlockingQueue.add(Object)
-
addMove
public void addMove(int moveThreadIndex, int stepIndex, int moveIndex, Move<Solution_> move, Score score)This method is thread-safe. It can be called from any move thread.- Parameters:
moveThreadIndex-0 <= moveThreadIndex < moveThreadCountstepIndex- at least 0moveIndex- at least 0move- never nullscore- never null- See Also:
BlockingQueue.add(Object)
-
addExceptionThrown
public void addExceptionThrown(int moveThreadIndex, Throwable throwable)This method is thread-safe. It can be called from any move thread. Previous results (that haven't been consumed yet), will still be returned during iteration before the iteration throws an exception, unless there's a lower moveIndex that isn't in the queue yet.- Parameters:
moveThreadIndex-0 <= moveThreadIndex < moveThreadCountthrowable- never null
-
take
public OrderByMoveIndexBlockingQueue.MoveResult<Solution_> take() throws InterruptedException
Not thread-safe. Can only be called from the solver thread.- Returns:
- never null
- Throws:
InterruptedException- if interrupted- See Also:
BlockingQueue.take()
-
-