/** * Tries to get a read-only copy of the State and execute {@code work} on it. * Cancels all cancelable readers before executing the {@link IUnitOfWork}. * For interactive jobs that need fastest possible execution. * * @param work Work to execute on the State * @param defaultResult Supplies a result in case the State is null * @param exceptionHandler Supplies a result in case an exception is raised during execution * * @return The result of executing {@code work}, * the result of querying {@code defaultResult} if the State is null, or * the result of executing {@code exceptionHandler} in case an exception is raised * @since 2.14 * @see CancelableUnitOfWork */ default <Result> Result tryPriorityReadOnly( IUnitOfWork<Result, State> work, Supplier<? extends Result> defaultResult, Function<? super Exception, ? extends Result> exceptionHandler ) { try { return tryPriorityReadOnly(work, defaultResult); } catch (Exception e) { return exceptionHandler.apply(e); } } }
/** * Tries to get a read-only copy of the State and execute {@code work} on it. * Cancels all cancelable readers before executing the {@link IUnitOfWork}. * For interactive jobs that need fastest possible execution. * * @param work Work to execute on the State * * @return The result of executing {@code work}, or * null if the State is null * @since 2.15 * @see CancelableUnitOfWork */ default <Result> Result tryPriorityReadOnly(IUnitOfWork<Result, State> work) { return tryPriorityReadOnly(work, () -> null); }