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()
 
 - 
 
 -