java.util.concurrent - Understanding java executor service shutdown and awaitTermination -


निम्न व्यवहार को स्पष्ट करने की आवश्यकता है

मेरे पास java.util.concurrent.ExecutorService के साथ एक जावा ऐप है,

  के लिए (int i = 0; i & lt; धागा_ग्रेड; i ++) {रननबल वर्कर = नया मैथ्रेड (बैच सिज़); executor.execute (कार्यकर्ता); } Executor.shutdown (); निष्पादक। प्रवेश परीक्षा (15, टाइम यूनिट। एमआईएनयूटीईएस); System.out.println ("सभी धागे समाप्त हो गए हैं");  

उपरोक्त कोड में मेरे पास 5 धागे हैं और ये 10 मिनट में समाप्त होते हैं और यह System.out.println ("सभी थ्रेड समाप्त हो चुके हैं") निष्पादित करेगा , यहां तक ​​कि हालांकि निष्पादक। इंतजार कर रहा है (15, टाइम यूनेट। एमआईएनटीईएस) 15 मिनट प्रतीक्षा समय है।

लेकिन जब मैं executor.shutdown () को हटा देता हूं प्रोग्राम 15 मिनट का इंतजार करेगा जो कि अगले लाइन को निष्पादित करने से पहले निष्पादक.वाइटटिमिनेशन (15, टाइम यूनेट। एमआईएनटीईएस) स्टेटमेंट में निर्दिष्ट है।

क्या कोई इस व्यवहार को समझा सकता है? बिना किसी शटडाउन कमान का समय निर्धारित राशि तक इंतजार करना चाहिए, हालांकि सभी धागे समाप्त हो गए हैं?

Javadoc for says :

जब तक कि सभी कार्यों को बंद करने के अनुरोध के बाद निष्पादन पूरा नहीं किया जाता है, या समय समाप्त होने पर या मौजूदा थ्रेड बाधित है, जो भी पहले होता है

इसलिए जब आप शटडाउन () कॉल करते हैं: आपके धागे 10 मिनट में समाप्त होते हैं

लेकिन अगर आप शट डाउन () को कॉल निकालते हैं, तो कोई शटडाउन अनुरोध नहीं है, इसलिए इंतजार करें जब तक टाइमआउट गुजरता नहीं होता तब तक वापसी नहीं होती (15 मिनट)


Comments

Popular posts from this blog

java - Can't add JTree to JPanel of a JInternalFrame -

c++ - Qt-how to convert a QByteArray to struct -

c# - How to know the number of Threads created and limit the Tasks accordingly -