एक जेनेरिक (java.lang.Exception) अपवाद फेंकने के लिए क्यों निराश किया जाता है, जब यह आमतौर पर किसी विधि के भीतर सबसे सशर्त विफलताओं को संभालने के लिए पर्याप्त होता है? मैं समझता हूं कि यदि कोई विधि कई प्रकार के अपवादों को फेंक सकती है तो अपवाद के विशिष्ट उप-वर्गों को फेंकने से थोड़ा सा प्रबंधन स्पष्ट हो सकता है, लेकिन सामान्य विफल/सफल मामले में मुझे लगता है कि अपवाद पर्याप्त से अधिक कार्य करता है।जेनेरिक अपवाद फेंकने से हतोत्साहित?
उत्तर
समस्या यह है कि Exception
भी RuntimeException
की सुपर क्लास है, जो कुछ सामान है कि पकड़ा नहीं किया जाना चाहिए शामिल है के रूप में यह एक असाधारण से प्रोग्रामिंग के साथ कोई समस्या इंगित करता बल्कि है संदर्भ से उत्पन्न होने वाली स्थिति। आप सामान्य परिस्थितियों में एक BufferOverflowException या असमर्थित ऑपरेशन अपवाद को पकड़ना नहीं चाहते हैं। इसके अलावा, अलग अपवाद प्रकारों को फेंकने से प्रत्येक को संभालने के तरीके पर कॉलिंग कोड नियंत्रण मिलता है। नई मल्टी-कैच फीचर के साथ जावा 7 में बॉयलरप्लेट कम हो गया है।
यह एक और महत्वपूर्ण समस्या है, +1। –
@MarkPeters हालांकि मैं शायद ही कभी "कभी नहीं" कहता हूं, क्योंकि मुझे लगता है कि सबसे खराब एंटी-पैटर्न भी विपरीत परिस्थितियों में सही जवाब हो सकता है, अपवादों से सावधान रहना सबसे अच्छा है। कभी-कभी उन्हें कोड द्वारा संभाला जाना होगा जिसे आपने नहीं लिखा था और आप पूरी दुकान में अनावश्यकता को खत्म कर देंगे। फिर, ज़ाहिर है, ऐसे लोग हैं जो 'थ्रोबल' पकड़ते हैं जैसे कि यह कोई बड़ा सौदा नहीं है: डी –
+1 - वास्तव में बहुत अच्छा बिंदु। – DerMike
आप अधिक विशिष्ट अपवाद फेंक रहे हैं, तो यह है कि एक Exception
कैच ब्लॉक में उन सभी के साथ काम करने से किसी भी बुला कोड नहीं रूकती है। अधिक विशिष्ट होने के कारण यह और अधिक दस्तावेज है कि किस प्रकार की त्रुटियां होती हैं, जिससे प्रोग्रामर के लिए अलग-अलग निपटना आसान हो जाता है।
साथ ही, फेंक "अपवाद" ही आप मूल रूप से अपने कोड की कॉल है कि वे अपवाद के किसी भी वर्ग से इनकार नहीं कर सकते हैं कह रहे हैं से। एक IOException
एक NumberFormatException
कर सकते हैं, हो सकता है, आदि
आम तौर पर आप को पता है आप एप्लिकेशन में क्या हुआ और केवल विशिष्ट अपवाद को पकड़ने और कार्यक्रम असफल जाने (या निष्पादन के क्रम में ऊपर जाते) जब आप अपवाद है कि आप विशेष रूप से लक्षित नहीं करते प्राप्त करना चाहते हैं। पकड़ने की अपवाद उन्हें सभी पकड़ लेगी और कुछ मामलों में आप नहीं जान पाएंगे कि आपका प्रोग्राम असफल रहा है।
हमेशा की तरह: यह निर्भर करता है।
मुझे लगता है कि एपीआई के बीच एक अंतर है जिसे आप दूसरों के सामने प्रकट करते हैं। यह कुछ समय के लिए जी सकता है। उस स्थिति में आप नहीं जानते कि कॉलर अपने मामले के लिए सबसे अच्छा क्या मानता है।
दूसरी ओर वहाँ हमेशा पर कोड है कि आप केवल अपने आप के लिए आंतरिक रूप से इस्तेमाल करते हैं। एक सामान्य अपवाद फेंकने के लिए पर्याप्त हो सकता है। लेकिन याद रखें, कि आप बाद में कुछ अपवाद हैंडलिंग बदलना चाहेंगे। यह कठिन होगा जब सभी त्रुटि मामलों को एक साथ जोड़ दिया जाता है।
जीएच के लिए डिटोस। मैं आपके वास्तविक एप्लिकेशन अपवादों के साथ उसी ब्लॉक में पकड़ने के लिए शायद अपवादों के प्रकार के अधिक स्पष्ट उदाहरणों के रूप में "शून्य सूचक अपवाद" और "स्मृति अपवाद से बाहर" का उपयोग करता।
मैं भी जोड़ते हैं वह यह है कि यह भविष्य विस्तार के लिए एक छोटे से प्रयास करने के लिए जाने के लिए भुगतान करता है। यदि आप जगह पर जेनेरिक अपवाद फेंकते हैं, और बाद में आप तय करते हैं कि आपको कुछ अपवादों को पकड़ने की जरूरत है, न कि दूसरों को, यह वापस जाने और उन्हें बदलने के लिए एक बड़ा दर्द हो सकता है। लेकिन अगर आप अपवाद बनाते हैं तो आपको जिस चीज के साथ जाना पड़ता है, वह इतना बड़ा सौदा नहीं है। एक नया अपवाद वर्ग बनाना जो सिर्फ एक संदेश के साथ एक कन्स्ट्रक्टर स्वीकार करता है, क्या, 5 लाइन कोड? यह भविष्य के लिए अच्छा निवेश है।
प्रोग्रामिंग में बहुत सी बातें की तरह, यह कितनी दूर तुम जाओ का एक सवाल है। मैं आमतौर पर लगभग हर प्रोजेक्ट में एक सामान्य "BadInputException" बनाता हूं, जिस पर मैं काम करता हूं, और इसे किसी भी समय उपयोगकर्ता इनपुट मान्यता मानदंडों में विफलता देता हूं। फिर मैं BadInputException को पकड़ सकता हूं और स्क्रीन पर संदेश फेंक सकता हूं। अगर मैं एक जटिल वर्ग बनाता हूं जो असंगत डेटा और उस तरह की चीज के लिए अपवाद फेंकता है, तो मैं आमतौर पर इसके लिए एक अपवाद वर्ग बना देता हूं। जैसे कि मैं "TalkToDatabase" कक्षा बनाता हूं, मैं एक "TalkToDatabaseException" बनाउंगा। (शायद उससे अधिक अगर कई प्रकार के अपवाद हैं तो मुझे पता है कि मैं पकड़ना चाहता हूं, लेकिन कम से कम एक।)
और वैसे, मुझे नहीं पता कि आप इसके बारे में सोच रहे हैं, लेकिन मैं त्रुटि के प्रकार को निर्धारित करने के लिए एक त्रुटि संदेश के पाठ की जांच करना दृढ़ता से हतोत्साहित करता हूं। मैं कार्यक्रमों जहां वे हर जगह सामान्य अपवाद फेंक देखा है, और फिर पकड़ ब्लॉक में वे कोड
// Very bad idea! Don't do this!
catch (Exception ex)
{
if (ex.getMessage().equals("Invalid foo"))
... handle bad foo ...
else if (ex.getMessage().equals("Plugh is over maximum"))
... handle bad plugh ...
... etc ...
}
की तरह यह बहुत बेहतर होगा सिर्फ इन मामलों के लिए अलग अपवाद बनाने के लिए किया है। न केवल प्रसंस्करण अधिक कुशल होगा, लेकिन मान लीजिए कि आप उपर्युक्त करते हैं और कोई बाद में आता है और संदेश को "फू अमान्य" में बदलने का निर्णय लेता है? कार्यक्रम अभी भी संकलित होगा, लेकिन यह सही ढंग से काम नहीं करेगा।
- 1. अपवाद फेंकने
- 2. सी # फ़ाइनलाइज़र फेंकने अपवाद?
- 3. ऑटोफोकस फेंकने का अपवाद
- 4. अपवाद फेंकने सेगमेंटेशन गलती
- 5. अपवाद फेंकने और पकड़ने
- 6. फेंकने और समारोह से पकड़ने अपवाद
- 7. विंडोज सेवा में अपवाद फेंकने
- 8. अपरिवर्तनीय अपवाद को फेंकने योग्य
- 9. अपवाद फेंकने के बाद लौटने
- 10. फेंकने वाले सी ++ अपवाद (0xE06D7363)
- 11. अपवाद को फेंकने वाली फाइलें
- 12. बूस्ट म्यूटेक्स फेंकने (विषम?) अपवाद
- 13. फेंकने के लिए क्या अपवाद?
- 14. जावा: अपवाद-फेंकने वाला वर्ग?
- 15. android.media.audiofx.Visualizer हर दूसरे समय अपवाद फेंकने
- 16. एसिंक्रोनस जावास्क्रिप्ट में फेंकने वाले अपवाद
- 17. इसे फिर से फेंकने के लिए अपवाद क्यों पकड़ें?
- 18. एस्पेक्टजे में अपवाद को फिर से फेंकने के लिए
- 19. एक एक्सेसर से अपवाद फेंकने के लिए खराब डिजाइन निर्णय?
- 20. कुछ भी नहीं फेंकने पर अपवाद दक्षता
- 21. एएसपी.नेट एमवीसी - अपवाद फेंकने के लिए कहां?
- 22. अपवाद फेंकने के लिए अगर कथन?
- 23. एंड्रॉइड: जेनेरिक नल पॉइंटर अपवाद
- 24. डब्ल्यूसीएफ आरईएसटी सेवाएं - जेनेरिक अपवाद हैंडलिंग
- 25. क्या कोई अपवाद रूपांतरण से अपवाद फेंकने का कोई बहाना है?
- 26. पकड़े गए अपवाद के तर्क के साथ फेंकने और फेंकने के बीच क्या अंतर है?
- 27. कस्टम जेनेरिक इडेंटिय के साथ सीरियलाइजेशन अपवाद?
- 28. क्या घोषणा को फेंकने के बिना अपवाद फेंकने का कोई तरीका है?
- 29. क्या मुझे अपवाद फेंकने के बाद तोड़ना है?
- 30. एक पार्सिंग त्रुटि होने पर फेंकने के लिए उपयुक्त अपवाद?
[जावा या सी # में अपवाद प्रबंधन के लिए सर्वोत्तम प्रथाओं] के संभावित डुप्लिकेट (http://stackoverflow.com/questions/409563/best-practices-for-exception-management-in-java-or-c-sharp) –