मैं जानना चाहता हूं कि चलने योग्य और चलने वाले राज्यों के बीच एक थ्रेड आगे और आगे कैसे चलता है। दृश्यों के पीछे वास्तव में क्या होता है। मुझे लगता है कि थ्रेडपूल के मामले में इसकी आवश्यकता होगी लेकिन मैं पूरी तरह से समझने में सक्षम नहीं हूं। कृपया मदद करें मुझे यह समझने के लिए।थ्रेड चलने योग्य स्थिति में चलने से कैसे चलता है?
उत्तर
अगर धागा राज्य का मतलब है कि अपने को क्रियान्वित रन() विधि और जब runnable विधि में अपनी चल रहा है इसकी निष्पादन शुरूआत() विधि .... तो मुझे लगता है कि रननेबल से चलने से चलने का मतलब है कि यह रन() से शुरू करने के लिए वापस जा रहा है()
अधिकांश ऑपरेटिंग सिस्टमों के नामकरण में, "चलने" का अर्थ है कि थ्रेड वास्तव में कुछ CPU पर निर्देशों को निष्पादित कर रहा है, और "रननेबल" का अर्थ है कि किसी भी CPU को चलाने के लिए थ्रेड को "चलने" से रोकता है।
एक जावा प्रोग्राम उन दो राज्यों के बीच अंतर नहीं बता सकता है। धागा बताता है कि जावा के बारे में पता है कि नया, अनावश्यक, अवरुद्ध, प्रतीक्षा, TIMED_WAITING, और समाप्त हो गया है।
t.start()
से पहले एक धागा नया है, और यह कभी भी बाद में वापस नहीं जा सकता है। प्रतीक्षा और TIMED_WAITING दोनों का मतलब है कि धागा किसी अन्य धागे में notify()
कॉल के लिए प्रतीक्षा कर रहा है। ब्लॉक्ड का मतलब है कि यह किसी और चीज की प्रतीक्षा कर रहा है (उदाहरण के लिए, synchronized
ब्लॉक दर्ज करने के लिए), और टर्मिनट का मतलब है कि यह समाप्त हो गया है।
Yield
एक स्थिर विधि है जो वर्तमान में निष्पादित थ्रेड को थ्रेड पूल में समान प्राथमिकता वाले धागे का मौका देने के लिए कहती है।
कोई गारंटी नहीं है कि Yield
वर्तमान में निष्पादन योग्य थ्रेड को तुरंत चलने योग्य राज्य में कर देगा। एक महत्वपूर्ण बिंदु याद रखें कि उपज विधि थ्रेड को प्रतीक्षा या अवरुद्ध स्थिति में नहीं जाने देती है। यह केवल रनिंग स्टेट से रननेबल स्टेट तक धागा बना सकता है। एक प्रोग्रामर की मार्गदर्शिका का
'उपज()' शायद ही कभी बुलाया जाता है, और यह निश्चित रूप से यहां काम पर प्रमुख तंत्र नहीं है। कोड के लिए कोड स्वरूपण का उपयोग न करें जो कोड नहीं है। – EJP
@Anand ..... स्पष्टीकरण के लिए धन्यवाद। बस एक और संदेह .... हम अपने कोड में मैन्युअल रूप से उपज का उपयोग करेंगे ... सही? JVM इस पर अपना ख्याल कैसे रखता है? –
* "इस बात की कोई गारंटी नहीं है कि यील्ड वर्तमान में चलने योग्य राज्य को तत्काल निष्पादित करने के लिए थ्रेड करेगा।" * ... दरअसल। जब Jread.yield() का आह्वान किया जाता है तो यह पूरी तरह से कुछ भी करने के लिए JVM के लिए पूरी तरह से स्वीकार्य नहीं होगा। एक प्रोग्राम जो इसकी शुद्धता के लिए थ्रेड.इल्ड() के व्यवहार पर निर्भर करता है, वह एक गैर-पोर्टेबल प्रोग्राम है, और सबसे खराब त्रुटिपूर्ण प्रोग्राम सबसे खराब है। – scottb
निकालें जावा SCJP प्रमाणन के लिए: धागे:
static void उपज() इस विधि अस्थायी रूप से इसके निष्पादन रोक सकते हैं और, इस प्रकार, अन्य थ्रेड निष्पादित करने के लिए अनुमति देने के लिए वर्तमान धागा कारण बनता है। यह तय करने के लिए JVM तक है कि यह संक्रमण कब और कब होगा।
स्थैतिक शून्य नींद (लंबी मिलीसेक) इंटरप्टेड एक्सेप्शन फेंकता है वर्तमान धागा निर्दिष्ट समय के लिए फिर से चलाने के लिए योग्य होने से पहले सो जाता है।
अंतिम शून्य में शामिल होने के() फेंकता InterruptedException अंतिम शून्य में शामिल होने के (लंबी millisec) फेंकता InterruptedException एक धागे पर लागू इन दोनों तरीकों में से किसी को एक कॉल प्रतीक्षा करें और नहीं होंगे लौट जब तक या तो धागा पूरा कर लिया है या यह समय समाप्त हो गया है क्रमशः निर्दिष्ट समय के बाद।
शून्य इंटरप्ट() विधि उस थ्रेड को बाधित करती है जिस पर इसे बुलाया जाता है। प्रतीक्षा-के-अधिसूचना, सोना, या अवरुद्ध-शामिल-समापन-समापन राज्यों में, थ्रेड को एक इंटरप्टेड अपवाद प्राप्त होगा।
उदाहरण नीचे थ्रेड राज्यों के बीच संक्रमण को दर्शाता है। (1) पर एक थ्रेड थोड़ा (2) सोता है और फिर (3) पर लूप में कुछ गणना करता है, जिसके बाद धागा समाप्त हो जाता है। मुख्य() विधि थ्रेड (4) पर थ्रेड में धागे की निगरानी करता है, getState() विधि द्वारा लौटा धागा राज्य मुद्रित करता है। आउटपुट से पता चलता है कि थ्रेड रननेबल स्थिति के माध्यम से जाता है जब रन() विधि निष्पादित होने लगती है और फिर TIMED_WAITING स्थिति में सो जाती है। जागने पर, यह रननेबल स्थिति में लूप की गणना करता है, और रन() विधि समाप्त होने पर टर्मिनेटेड स्थिति में स्थानांतरित होता है।
उदाहरण: थ्रेड स्टेट्स
public class ThreadStates {
private static Thread t1 = new Thread("T1") { // (1)
public void run() {
try {
sleep(2); // (2)
for(int i = 10000; i > 0; i--); // (3)
} catch (InterruptedException ie){
ie.printStackTrace();
}
}
};
public static void main(String[] args) {
t1.start();
while(true) { // (4)
Thread.State state = t1.getState();
System.out.println(state);
if (state == Thread.State.TERMINATED) break;
}
}
}
कार्यक्रम से
संभावित उत्पादन:
RUNNABLE
TIMED_WAITING
...
TIMED_WAITING
RUNNABLE
...
RUNNABLE
TERMINATED
- 1. थ्रेड में चलने योग्य रननेबल क्यों संभव नहीं है?
- 2. एक चलने योग्य div
- 3. क्यों "चलने योग्य लागू" "थ्रेड फैला" पर पसंदीदा है?
- 4. कॉपी करने योग्य नहीं है, लेकिन चलने योग्य, C++
- 5. चलने योग्य जार छवियां/फ़ाइलें (संसाधन)
- 6. jQuery चलने योग्य मॉडल संवाद बॉक्स
- 7. jvm args के साथ चलने योग्य जार
- 8. जावा लंबी चलने कार्य थ्रेड बीच में बनाम झंडा
- 9. लांग तक चलने वाले 'COMMIT' 'निष्क्रिय' स्थिति से pg_stat_activity
- 10. सी # लाइब्रेरी में मुख्य थ्रेड में चलने का पता लगाना
- 11. पृष्ठभूमि में चलने से एप्लिकेशन को रोकें?
- 12. डब्ल्यूपीएफ एमवीवीएम आइटम्स कंट्रोल के साथ चलने योग्य आकार
- 13. जावास्क्रिप्ट चलने वाला कोड
- 14. Iterative पेड़ चलने
- 15. std :: map में एक गैर-प्रतिलिपि योग्य और गैर-चलने योग्य ऑब्जेक्ट आवंटित कैसे करें?
- 16. लंबे समय से चलने वाले यूनिट परीक्षण
- 17. ग्रहण: चलने से कोड रोकें (जावा)
- 18. लंबे समय से चलने वाले पायथन स्क्रिप्ट
- 19. रेलवे को कैसे रोकें 3.1 लेनदेन में चलने से माइग्रेशन?
- 20. लिंक्ड सूची प्रविष्टि चलने का समय भ्रम की स्थिति
- 21. स्थिति एक दूसरे के नीचे सीधे चलने वाले तत्व
- 22. sqlalchemy: एक लंबे समय से चलने वाली क्वेरी को रोकना
- 23. लोचदार खोज बहुत से चलने वाले धागे
- 24. एचटीएमएल 5 में चिकना चलने वाले sprites
- 25. मैं एक गैर-चलने योग्य (लेकिन कॉपी करने योग्य) ऑब्जेक्ट कैसे वापस कर सकता हूं?
- 26. एक फ्लास्क चलने वाले वेब एप्लिकेशन
- 27. sqlplus प्रिंट चलने वाला कथन
- 28. पुन: चलने में असफल और परीक्षण नहीं
- 29. क्या चलने योग्य जार (ग्रहण के माध्यम से) ट्रैकिंग जानकारी शामिल है?
- 30. गणित में समानांतर चलने वाले कितने कर्नल?
आपको क्यों जानने की आवश्यकता है? मुझे यह भी पता नहीं है, लेकिन इस तरह के ज्ञान के बिना सफलतापूर्वक 'थ्रेडपूल' का उपयोग किया है। –
मैं बस सोच रहा था ..... अगर धागा चल रहा है, तो इसका मतलब है कि इसकी निष्पादन चलाने() विधि और जब इसकी चलने योग्य विधि में इसकी निष्पादन प्रारंभ() विधि .... तो मुझे लगता है कि चलने योग्य से चलने से चल रहा है रन() से शुरू करने के लिए() .... कृपया मुझे सही करें अगर मैं गलत हूं क्योंकि मैं –
को मल्टीथ्रेड करने के लिए शुरुआत कर रहा हूं, मुझे यह प्रश्न पसंद है, और यदि यह डुप्ली नहीं है, तो मैं इसे खोलने के लिए वोट देता हूं। –