ThreadPoolExecutor वर्ग

java.util.concurrent.ThreadPoolExecutor एक निष्पादित कार्य को निष्पादित करने के लिए एक निष्पादित कार्य है, जो संभवतः कई पूल किए गए थ्रेड्स में से एक का उपयोग करके, आमतौर पर एक्सेकॉर्स फ़ैक्टरी विधियों का उपयोग करके कॉन्फ़िगर किया गया है। यह वर्तमान थ्रेड आंकड़ों की जांच करने और उन्हें नियंत्रित करने के लिए विभिन्न उपयोगिता विधियां भी प्रदान करता है।

ThreadPoolExecutor मेथड्स

अनु क्रमांक। विधि और विवरण
1

protected void afterExecute(Runnable r, Throwable t)

विधि दी गई रननीय के निष्पादन के पूरा होने पर आह्वान की गई।

2

void allowCoreThreadTimeOut(boolean value)

यह निर्धारित करने वाली नीति निर्धारित करता है कि क्या कोर थ्रेड्स समय से समाप्त हो सकते हैं और समाप्त हो सकते हैं यदि कोई कार्य रखने के समय के भीतर नहीं आते हैं, तो नए कार्यों के आने पर प्रतिस्थापित किया जा सकता है।

3

boolean allowsCoreThreadTimeOut()

सही है अगर यह पूल कोर थ्रेड्स को समय-समय पर समाप्त करने की अनुमति देता है और अगर कोई कार्य नहीं रखा जाता है, तो नए कार्यों के आने पर आवश्यक समय पर प्रतिस्थापित किया जा सकता है।

4

boolean awaitTermination(long timeout, TimeUnit unit)

जब तक सभी कार्यों को एक शटडाउन अनुरोध के बाद निष्पादन पूरा नहीं किया जाता है, या समय समाप्त होता है, या वर्तमान धागा बाधित होता है, जो भी पहले हो।

5

protected void beforeExecute(Thread t, Runnable r)

विधि दिए गए धागे में दिए गए Runnable को निष्पादित करने से पहले लागू किया गया है।

6

void execute(Runnable command)

भविष्य में किसी समय दिए गए कार्य को निष्पादित करता है।

7

protected void finalize()

जब यह निष्पादक अब संदर्भित नहीं होता है, तो शटडाउन बंद हो जाता है और इसके कोई सूत्र नहीं होते हैं।

8

int getActiveCount()

सक्रिय रूप से कार्य निष्पादित करने वाले थ्रेड्स की अनुमानित संख्या देता है।

9

long getCompletedTaskCount()

निष्पादन को पूरा करने वाले कार्यों की अनुमानित कुल संख्या लौटाता है।

10

int getCorePoolSize()

धागे की कोर संख्या देता है।

1 1

long getKeepAliveTime(TimeUnit unit)

थ्रेड को जीवित समय पर लौटाता है, जो कि मुख्य पूल आकार के अतिरिक्त थ्रेड्स समाप्त होने से पहले निष्क्रिय रह सकता है।

12

int getLargestPoolSize()

सबसे बड़ी संख्या में धागे हैं जो कभी भी एक साथ पूल में रहे हैं।

13

int getMaximumPoolSize()

थ्रेड्स की अधिकतम अनुमत संख्या देता है।

14

int getPoolSize()

पूल में थ्रेड्स की वर्तमान संख्या देता है।

15

BlockingQueue getQueue()

इस निष्पादक द्वारा उपयोग की जाने वाली कार्य कतार देता है।

15

RejectedExecutionHandler getRejectedExecutionHandler()

अप्राप्य कार्यों के लिए वर्तमान हैंडलर लौटाता है।

16

long getTaskCount()

निष्पादन के लिए निर्धारित किए गए कार्यों की अनुमानित कुल संख्या लौटाता है।

17

ThreadFactory getThreadFactory()

नई थ्रेड बनाने के लिए उपयोग किए गए थ्रेड फ़ैक्टरी लौटाता है।

18

boolean isShutdown()

यदि यह निष्पादक बंद कर दिया गया है तो सही है।

19

boolean isTerminated()

यदि सभी कार्य शट डाउन के बाद पूरे हो गए हैं, तो सही है।

20

boolean isTerminating()

यदि यह निष्पादक शटडाउन () या शटडाउन नोव () के बाद समाप्त होने की प्रक्रिया में है, लेकिन यह पूरी तरह से समाप्त नहीं हुआ है तो सही है।

21

int prestartAllCoreThreads()

सभी मुख्य थ्रेड्स शुरू करता है, जिससे उन्हें काम का इंतजार करना पड़ता है।

22

boolean prestartCoreThread()

एक कोर धागा शुरू करता है, जिससे यह काम के लिए मूर्खतापूर्ण प्रतीक्षा करता है।

23

void purge()

रद्द किए जाने वाले सभी भावी कार्यों को कार्य कतार से निकालने की कोशिश करता है।

24

boolean remove(Runnable task)

इस कार्य को निष्पादक की आंतरिक कतार से हटा देता है यदि यह मौजूद है, तो इस प्रकार इसे चलाने के लिए नहीं है अगर यह पहले से ही शुरू नहीं हुआ है।

25

void setCorePoolSize(int corePoolSize)

थ्रेड्स की मुख्य संख्या सेट करता है।

26

void setKeepAliveTime(long time, TimeUnit unit)

उस समय सीमा को निर्धारित करता है जिसके लिए समाप्त होने से पहले धागे निष्क्रिय रह सकते हैं।

27

void setMaximumPoolSize(int maximumPoolSize)

थ्रेड्स की अधिकतम अनुमत संख्या सेट करता है।

28

void setRejectedExecutionHandler(RejectedExecutionHandler handler)

अलौकिक कार्यों के लिए एक नया हैंडलर सेट करता है।

29

void setThreadFactory(ThreadFactory threadFactory)

नए धागे बनाने के लिए इस्तेमाल की जाने वाली धागा फैक्टरी सेट करती है।

30

void shutdown()

एक अर्दली शटडाउन की पहल करता है जिसमें पहले सबमिट किए गए कार्यों को निष्पादित किया जाता है, लेकिन कोई नया कार्य स्वीकार नहीं किया जाएगा।

31

List<Runnable> shutdownNow()

सभी सक्रिय रूप से निष्पादित कार्यों को रोकने का प्रयास, प्रतीक्षा कार्यों के प्रसंस्करण को रोकता है, और उन कार्यों की एक सूची देता है जो निष्पादन का इंतजार कर रहे थे।

32

protected void terminated()

जब एक्सक्लूसिव समाप्त हो गया है तो विधि का इस्तेमाल किया जाता है।

33

String toString()

इस पूल की पहचान करने वाले एक स्ट्रिंग को लौटाता है, साथ ही साथ इसके राज्य को भी चलाता है, जिसमें रन स्टेट और अनुमानित कार्यकर्ता और कार्य गणना के संकेत शामिल हैं।

उदाहरण

निम्न TestThread प्रोग्राम थ्रेड-आधारित वातावरण में ThreadPoolExecutor इंटरफ़ेस का उपयोग दिखाता है।

import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

public class TestThread {
	
   public static void main(final String[] arguments) throws InterruptedException {
      ThreadPoolExecutor executor = (ThreadPoolExecutor)Executors.newCachedThreadPool();

      //Stats before tasks execution
      System.out.println("Largest executions: "
         + executor.getLargestPoolSize());
      System.out.println("Maximum allowed threads: "
         + executor.getMaximumPoolSize());
      System.out.println("Current threads in pool: "
         + executor.getPoolSize());
      System.out.println("Currently executing threads: "
         + executor.getActiveCount());
      System.out.println("Total number of threads(ever scheduled): "
         + executor.getTaskCount());

      executor.submit(new Task());
      executor.submit(new Task());

      //Stats after tasks execution
      System.out.println("Core threads: " + executor.getCorePoolSize());
      System.out.println("Largest executions: "
         + executor.getLargestPoolSize());
      System.out.println("Maximum allowed threads: "
         + executor.getMaximumPoolSize());
      System.out.println("Current threads in pool: "
         + executor.getPoolSize());
      System.out.println("Currently executing threads: "
         + executor.getActiveCount());
      System.out.println("Total number of threads(ever scheduled): "
         + executor.getTaskCount());

      executor.shutdown();
   }  

   static class Task implements Runnable {

      public void run() {

         try {
            Long duration = (long) (Math.random() * 5);
            System.out.println("Running Task! Thread Name: " +
               Thread.currentThread().getName());
            TimeUnit.SECONDS.sleep(duration);
            System.out.println("Task Completed! Thread Name: " +
               Thread.currentThread().getName());
         } catch (InterruptedException e) {
            e.printStackTrace();
         }
      }
   }
}

यह निम्नलिखित परिणाम का उत्पादन करेगा।

उत्पादन

Largest executions: 0
Maximum allowed threads: 2147483647
Current threads in pool: 0
Currently executing threads: 0
Total number of threads(ever scheduled): 0
Core threads: 0
Largest executions: 2
Maximum allowed threads: 2147483647
Current threads in pool: 2
Currently executing threads: 2
Total number of threads(ever scheduled): 2
Running Task! Thread Name: pool-1-thread-2
Running Task! Thread Name: pool-1-thread-1
Task Completed! Thread Name: pool-1-thread-1
Task Completed! Thread Name: pool-1-thread-2