एक्ज़ीक्यूसर सर्विस इंटरफ़ेस
एक java.util.concurrent.ExecutorService इंटरफ़ेस एक्ज़ीक्यूटर इंटरफ़ेस का उप-संस्करण है, और जीवनचक्र का प्रबंधन करने के लिए सुविधाओं को जोड़ता है, दोनों व्यक्तिगत कार्यों और निष्पादनकर्ता के ही।
एग्जिक्युरर्स सर्विस तरीके
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | boolean awaitTermination(long timeout, TimeUnit unit) जब तक सभी कार्यों को एक शटडाउन अनुरोध के बाद निष्पादन पूरा नहीं किया जाता है, या समय समाप्त होता है, या वर्तमान धागा बाधित होता है, जो भी पहले हो। |
2 | <T> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks) दिए गए कार्यों को निष्पादित करता है, सभी पूर्ण होने पर अपनी स्थिति और परिणाम पकड़े हुए फ्यूचर्स की सूची लौटाते हैं। |
3 | <T> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) दिए गए कार्यों को निष्पादित करता है, अपनी स्थिति और परिणामों को पकड़े हुए फ्यूचर्स की एक सूची लौटाता है और सभी पूर्ण या समय समाप्त होने पर, जो भी पहले हो। |
4 | <T> T invokeAny(Collection<? extends Callable<T>> tasks) दिए गए कार्यों को निष्पादित करता है, एक का परिणाम लौटाता है जो सफलतापूर्वक पूरा हो गया है (यानी, बिना किसी अपवाद के) यदि कोई हो। |
5 | <T> T invokeAny(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) दिए गए कार्यों को निष्पादित करता है, एक का परिणाम वापस लौटाता है जो सफलतापूर्वक पूरा हो गया है (यानी, एक अपवाद को फेंक दिए बिना), यदि कोई दिए गए समय समाप्त होने से पहले करते हैं। |
6 | boolean isShutdown() यदि यह निष्पादक बंद कर दिया गया है तो सही है। |
7 | boolean isTerminated() यदि सभी कार्य शट डाउन के बाद पूरे हो गए हैं, तो सही है। |
8 | void shutdown() एक अर्दली शटडाउन की पहल करता है जिसमें पहले सबमिट किए गए कार्यों को निष्पादित किया जाता है, लेकिन कोई नया कार्य स्वीकार नहीं किया जाएगा। |
9 | List<Runnable> shutdownNow() सभी सक्रिय रूप से निष्पादित कार्यों को रोकने का प्रयास, प्रतीक्षा कार्यों के प्रसंस्करण को रोकता है, और उन कार्यों की एक सूची देता है जो निष्पादन का इंतजार कर रहे थे। |
10 | <T> Future<T> submit(Callable<T> task) निष्पादन के लिए एक मान-लौटाने वाला कार्य प्रस्तुत करता है और भविष्य में कार्य के लंबित परिणामों का प्रतिनिधित्व करता है। |
1 1 | Future<?> submit(Runnable task) निष्पादन के लिए एक रनाने योग्य कार्य प्रस्तुत करता है और उस कार्य का प्रतिनिधित्व करने वाला भविष्य देता है। |
12 | <T> Future<T> submit(Runnable task, T result) निष्पादन के लिए एक रनाने योग्य कार्य प्रस्तुत करता है और उस कार्य का प्रतिनिधित्व करने वाला भविष्य देता है। |
उदाहरण
निम्न TestThread प्रोग्राम थ्रेड आधारित वातावरण में ExecutorService इंटरफ़ेस का उपयोग दिखाता है।
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
public class TestThread {
public static void main(final String[] arguments) throws InterruptedException {
ExecutorService executor = Executors.newSingleThreadExecutor();
try {
executor.submit(new Task());
System.out.println("Shutdown executor");
executor.shutdown();
executor.awaitTermination(5, TimeUnit.SECONDS);
} catch (InterruptedException e) {
System.err.println("tasks interrupted");
} finally {
if (!executor.isTerminated()) {
System.err.println("cancel non-finished tasks");
}
executor.shutdownNow();
System.out.println("shutdown finished");
}
}
static class Task implements Runnable {
public void run() {
try {
Long duration = (long) (Math.random() * 20);
System.out.println("Running Task!");
TimeUnit.SECONDS.sleep(duration);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
यह निम्नलिखित परिणाम का उत्पादन करेगा।
उत्पादन
Shutdown executor
Running Task!
shutdown finished
cancel non-finished tasks
java.lang.InterruptedException: sleep interrupted
at java.lang.Thread.sleep(Native Method)
at java.lang.Thread.sleep(Thread.java:302)
at java.util.concurrent.TimeUnit.sleep(TimeUnit.java:328)
at TestThread$Task.run(TestThread.java:39)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:439)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
at java.lang.Thread.run(Thread.java:662)