इस कोड में क्या गलत है
सार्वजनिक वर्ग SimpleThreadPool {सार्वजनिक स्थिर शून्य मुख्य (स्ट्रिंग [ ] आर्ग्स) {निष्पादक सेवा निष्पादक = निष्पादक। एनएफ़फिक्सट्रेडपूल (5); (इंट आई = 0; आई & lt; 2000; i ++) के लिए (रननबल वर्कर = नया वर्कर थ्रेड ("+ i"); executor.execute (कार्यकर्ता); } वर्कर थ्रेड ओबज = नया वर्करट्रेड (); Println (obj.getCount ()); executor.shutdown (); जबकि (! निष्पादक.सुरक्षित ()) {} System.out.println ("सभी धागे समाप्त"); }} क्लास वर्कर टू्रेड ऑप्लेट्स रननाबल {निजी स्ट्रिंग कमांड; निजी अस्थिर स्थैतिक इंट गणना; सार्वजनिक वर्कर थ्रेड () {} सार्वजनिक वर्कर थ्रेड (स्ट्रिंग्स) {this.command = s; } @ ओवरराइड पब्लिक वायड रन () {प्रयास करें {सिंक्रनाइज़ (इस) {processCommand (); }} पकड़ (बाधित ईक्सेप्शन ई) {e.printStackTrace (); }} प्राइवेट व्यर्थ प्रोसेस कॉमांड () इंटरवर्टेड एक्सपेशेशन फेंकता {count ++; System.out.println ("गणना" + गणना); //Thread.sleep(500); } @ ओवरराइड सार्वजनिक स्ट्रिंग toString () {this.command लौटें; } सार्वजनिक int getCount () {वापसी गणना; }}
मैं 2000 के रूप में गिनती का परिणाम प्राप्त करने की कोशिश कर रहा हूं और वह भी अंत में ... मेरे कोड में क्या गलत है ?? कैसे मैं यह सुनिश्चित कर सकता हूं कि गिनती हमेशा सही क्रम में बढ़ी है ?? मुझे अस्थिर या सिंक्रनाइज़ किए गए ब्लॉक या दोनों का उपयोग कब करना चाहिए ??
आप इस
पर सिंक्रनाइज़ कर रहे हैं। लेकिन जब आप ऐसा करते हैं, तो आपको प्रत्येक WorkerThread
लॉक करना होता है, जो उत्पादक नहीं है।
विधि processcommand
विधि परमाणु नहीं है, इसलिए आउटपुट आदेश से बाहर आओ इसके अलावा, वेतन वृद्धि भी परमाणु नहीं है; इसे मान पढ़ना, मान बढ़ा देना चाहिए, और मान को वापस चर में संग्रहीत करना होगा।
बनाना count
अस्थिर
केवल यह सुनिश्चित करता है कि एक अद्यतन मान
यदि आप एक ऑब्जेक्ट को सभी थ्रेडों में सिंक्रनाइज़ करते हैं ( WorkerThread.class यहां काम करेगा), फिर प्रत्येक
थ्रेड
अपडेट हो जाएगा और सुरक्षित रूप से प्रिंट कर देगा।
सिंक्रनाइज़ (वर्करट्रेड। क्लास) {processCommand (); }
यदि आप ठीक से ऊपर सिंक्रनाइज़ करते हैं, तो अस्थिर
यहां आवश्यक नहीं है, हालांकि यह कुछ भी चोट नहीं पहुँचाएगा; गिनती
तक पहुंच पूरी तरह से नियंत्रित है।
ध्यान दें: प्रश्न के लिखित में 2000
20000
; यह अब प्रासंगिक नहीं है।
साथ ही, 20000
प्राप्त करने के लिए, आप शायद 20000 कार्य करना चाहते हैं; वे प्रत्येक एक बार मान बढ़ाते हैं।
के लिए (int i = 0; i & lt; 20000; i ++) {
No comments:
Post a Comment