001 // Copyright 2009 The Apache Software Foundation
002 //
003 // Licensed under the Apache License, Version 2.0 (the "License");
004 // you may not use this file except in compliance with the License.
005 // You may obtain a copy of the License at
006 //
007 // http://www.apache.org/licenses/LICENSE-2.0
008 //
009 // Unless required by applicable law or agreed to in writing, software
010 // distributed under the License is distributed on an "AS IS" BASIS,
011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
012 // See the License for the specific language governing permissions and
013 // limitations under the License.
014
015 package org.apache.tapestry5.ioc.services;
016
017 import org.apache.tapestry5.ioc.Invokable;
018
019 import java.util.concurrent.Future;
020
021 /**
022 * A service that allows work to occur in parallel using a thread pool. The thread pool is started lazily, and is
023 * shutdown when the Registry is shutdown.
024 *
025 * @see org.apache.tapestry5.ioc.IOCSymbols
026 * @since 5.1.0.1
027 */
028 public interface ParallelExecutor
029 {
030 /**
031 * Submits the invocable object to be executed in a pooled thread. Returns a Future object representing the eventual
032 * result of the invocable's operation. The actual operation will be wrapped such that {@link
033 * PerthreadManager#cleanup()} is invoked after the operation completes.
034 *
035 * @param invocable to execute in a thread
036 * @param <T>
037 * @return Future result of that invocation
038 */
039 <T> Future<T> invoke(Invokable<T> invocable);
040
041 /**
042 * As with {@link #invoke(org.apache.tapestry5.ioc.Invokable)}, but the result is wrapped inside a {@linkplain
043 * org.apache.tapestry5.ioc.services.ThunkCreator thunk}. Invoking methods on the thunk will block until the value
044 * is available.
045 *
046 * @param proxyType return type, used to create the thunk
047 * @param invocable object that will eventually execute and return a value
048 * @param <T>
049 * @return the thunk
050 */
051 <T> T invoke(Class<T> proxyType, Invokable<T> invocable);
052 }