1. अपवादांचे प्रकार
सर्व अपवाद 4 प्रकारांमध्ये विभागलेले आहेत, जे प्रत्यक्षात एकमेकांना वारसा देणारे वर्ग आहेत.
Throwable
वर्ग
सर्व अपवादांसाठी मूळ वर्ग हा Throwable
वर्ग आहे. वर्गामध्ये Throwable
कोड असतो जो वर्तमान कॉल स्टॅक (वर्तमान पद्धतीचा स्टॅक ट्रेस) अॅरेवर लिहितो. स्टॅक ट्रेस म्हणजे काय ते आपण थोड्या वेळाने शिकू.
थ्रो ऑपरेटर केवळ क्लासमधून प्राप्त होणारी वस्तू स्वीकारू शकतो Throwable
. आणि जरी तुम्ही सैद्धांतिकदृष्ट्या कोड लिहू शकता जसे की throw new Throwable();
, सहसा कोणीही असे करत नाही. Throwable
सर्व अपवादांसाठी एकच पालक वर्ग असणे हा वर्गाचा मुख्य उद्देश आहे.
Error
वर्ग
पुढील अपवाद वर्ग हा Error
वर्ग आहे, जो थेट Throwable
वर्गाचा वारसा घेतो. जेव्हा गंभीर समस्या उद्भवतात तेव्हा Java मशीन वर्गाच्या Error
(आणि त्याचे वंशज) वस्तू तयार करते . उदाहरणार्थ, हार्डवेअर खराब होणे, अपुरी मेमरी इ.
सहसा, प्रोग्रामर म्हणून, प्रोग्राममध्ये अशी त्रुटी (ज्या प्रकारासाठी फेकली पाहिजे) अशा परिस्थितीत आपण काहीही करू शकत नाही : या त्रुटी खूप गंभीर आहेत. Error
तुम्ही फक्त वापरकर्त्याला सूचित करू शकता की प्रोग्राम क्रॅश होत आहे आणि/किंवा प्रोग्राम लॉगमध्ये त्रुटीबद्दल सर्व ज्ञात माहिती लिहा.
Exception
वर्ग
आणि वर्ग Exception
हे RuntimeException
बर्याच पद्धतींच्या ऑपरेशनमध्ये होणाऱ्या सामान्य त्रुटींसाठी आहेत. प्रत्येक फेकलेल्या अपवादाचे उद्दिष्ट एका ब्लॉकद्वारे पकडले जाणे आहे catch
ज्याला ते योग्यरित्या कसे हाताळायचे हे माहित आहे.
जेव्हा एखादी पद्धत काही कारणास्तव तिचे कार्य पूर्ण करू शकत नाही, तेव्हा योग्य प्रकारचा अपवाद टाकून कॉलिंग पद्धतीला त्वरित सूचित केले पाहिजे.
दुस-या शब्दात, जर व्हेरिएबल बरोबर असेल null
, तर पद्धत एक टाकेल NullPointerException
. जर चुकीच्या वितर्क पद्धतीला पास केले गेले, तर ते फेकले जाईल InvalidArgumentException
. जर पद्धत चुकून शून्याने भागली तर ती फेकून देईल ArithmeticException
.
RuntimeException
वर्ग
RuntimeExceptions
चे उपसंच आहेत Exceptions
. आम्ही असे म्हणू शकतो की RuntimeException
ही सामान्य अपवादांची हलकी आवृत्ती आहे ( Exception
) — अशा अपवादांवर कमी आवश्यकता आणि निर्बंध लादले जातात
Exception
तुम्ही नंतर आणि नंतर फरक शिकाल RuntimeException
.
2. Throws
: तपासलेले अपवाद
सर्व Java अपवाद 2 श्रेणींमध्ये येतात: चेक केलेले आणि अनचेक केलेले .
सर्व अपवाद ज्यांना वारसा मिळतो RuntimeException
किंवा अनचेक केलेले अपवादError
मानले जातात . इतर सर्व अपवाद तपासले आहेत .
तपासलेले अपवाद सादर केल्यानंतर वीस वर्षांनी, जवळजवळ प्रत्येक Java प्रोग्रामर याला बग समजतो. लोकप्रिय आधुनिक फ्रेमवर्कमध्ये, सर्व अपवादांपैकी 95% अनचेक केलेले आहेत. C# भाषा, ज्याने Java जवळजवळ कॉपी केली आहे, चेक केलेले अपवाद जोडले नाहीत .
चेक केलेले आणि अनचेक केलेल्या अपवादांमधील मुख्य फरक काय आहे ?
चेक केलेल्या अपवादांवर अतिरिक्त आवश्यकता लागू केल्या आहेत . ढोबळपणे बोलायचे तर ते असे आहेत:
आवश्यकता १
जर एखादी पद्धत चेक केलेला अपवाद टाकत असेल , तर त्याने त्याच्या स्वाक्षरीमध्ये अपवादाचा प्रकार सूचित केला पाहिजे . अशाप्रकारे, हा "अर्थपूर्ण अपवाद" होऊ शकतो याची त्याला कॉल करणारी प्रत्येक पद्धत माहित आहे.
कीवर्ड नंतर पद्धत पॅरामीटर्स नंतर चेक केलेले अपवाद दर्शवा ( चुकून कीवर्ड वापरू नका ). हे असे काहीतरी दिसते:throws
throw
type method (parameters) throws exception
उदाहरण:
तपासलेला अपवाद | अनचेक अपवाद |
---|---|
|
|
उजवीकडील उदाहरणामध्ये, आमचा कोड अनचेक केलेला अपवाद टाकतो — कोणत्याही अतिरिक्त कृतीची आवश्यकता नाही. डावीकडील उदाहरणामध्ये, पद्धत चेक केलेला अपवाद टाकते, म्हणून throws
कीवर्ड अपवादाच्या प्रकारासह पद्धत स्वाक्षरीमध्ये जोडला जातो.
जर एखाद्या पद्धतीला अनेक चेक केलेले अपवाद टाकण्याची अपेक्षा असेल , तर ते सर्व throws
स्वल्पविरामाने विभक्त करून कीवर्ड नंतर निर्दिष्ट केले जावेत. ऑर्डर महत्वाची नाही. उदाहरण:
public void calculate(int n) throws Exception, IOException
{
if (n == 0)
throw new Exception("n is null!");
if (n == 1)
throw new IOException("n is 1");
}
आवश्यकता 2
जर आपण एखाद्या पद्धतीला कॉल केला ज्याने त्याच्या स्वाक्षरीमध्ये अपवाद तपासले आहेत, तर आपण त्याकडे दुर्लक्ष करू शकत नाही.
catch
तुम्ही प्रत्येकासाठी ब्लॉक्स जोडून किंवा तुमच्या पद्धतीच्या क्लॉजमध्ये जोडून असे सर्व अपवाद पकडले पाहिजेत.throws
जणू काही आपण म्हणत आहोत, " हे अपवाद इतके महत्त्वाचे आहेत की आपण ते पकडले पाहिजेत. आणि जर आपल्याला ते कसे हाताळायचे हे माहित नसेल, तर जो कोणी आमची पद्धत कॉल करेल त्याला सूचित केले पाहिजे की असे अपवाद त्यात येऊ शकतात.
उदाहरण:
कल्पना करा की आपण मानवांनी भरलेले जग तयार करण्यासाठी एक पद्धत लिहित आहोत. लोकांची प्रारंभिक संख्या वाद म्हणून पास केली जाते. त्यामुळे खूप कमी लोक असल्यास अपवाद जोडणे आवश्यक आहे.
पृथ्वी निर्माण करणे | नोंद |
---|---|
|
पद्धत संभाव्यतः दोन तपासलेले अपवाद टाकते:
|
ही पद्धत कॉल 3 प्रकारे हाताळली जाऊ शकते:
1. कोणतेही अपवाद पकडू नका
हे बर्याचदा केले जाते जेव्हा पद्धत योग्यरित्या परिस्थिती कशी हाताळायची हे माहित नसते.
कोड | नोंद |
---|---|
|
कॉलिंग पद्धत अपवाद पकडत नाही आणि इतरांना त्यांच्याबद्दल माहिती दिली पाहिजे: ती त्यांना स्वतःच्या कलमात throws जोडते |
2. काही अपवाद पहा
आम्ही हाताळू शकणाऱ्या त्रुटी आम्ही हाताळतो. पण जे आम्हाला समजत नाही, आम्ही त्यांना कॉलिंग पद्धतीवर टाकतो. हे करण्यासाठी, आम्हाला थ्रो क्लॉजमध्ये त्यांचे नाव जोडण्याची आवश्यकता आहे:
कोड | नोंद |
---|---|
|
कॉलर फक्त एक चेक केलेला अपवाद पकडतो — LonelyWorldException . दुसरा अपवाद त्याच्या स्वाक्षरीमध्ये जोडला जाणे आवश्यक आहे, जो कीवर्ड नंतर सूचित throws करतो |
3. सर्व अपवाद पहा
जर पद्धत कॉलिंग पद्धतीला अपवाद देत नसेल, तर कॉलिंग पद्धत नेहमी खात्री बाळगते की सर्वकाही चांगले कार्य करते. आणि ते अपवादात्मक परिस्थितीचे निराकरण करण्यासाठी कोणतीही कृती करण्यास अक्षम असेल.
कोड | नोंद |
---|---|
|
सर्व अपवाद या पद्धतीत पकडले जातात. कॉलरला विश्वास असेल की सर्वकाही चांगले झाले आहे. |
3. अनेक अपवाद पकडणे
प्रोग्रामरना कोड डुप्लिकेट करणे खरोखरच आवडत नाही. त्यांनी सुसंगत विकास तत्त्व देखील आणले - DRY : स्वतःची पुनरावृत्ती करू नका. परंतु अपवाद हाताळताना, वारंवार असे प्रसंग येतात जेव्हा एका try
ब्लॉकनंतर catch
एकाच कोडसह अनेक ब्लॉक येतात.
catch
किंवा त्याच कोडसह 3 ब्लॉक आणि catch
इतर समान कोडसह आणखी 2 ब्लॉक असू शकतात . जेव्हा तुमचा प्रकल्प अपवादांना जबाबदारीने हाताळतो तेव्हा ही एक मानक परिस्थिती असते .
आवृत्ती 7 पासून प्रारंभ करून, जावा भाषेत एकाच catch
ब्लॉकमध्ये अनेक प्रकारचे अपवाद निर्दिष्ट करण्याची क्षमता जोडली आहे. हे अंदाजे असे दिसते:
try
{
// Code where an exception might occur
}
catch (ExceptionType1 | ExceptionType2 | ExceptionType3 name)
{
// Exception handling code
}
catch
तुम्हाला हवे तितके ब्लॉक्स असू शकतात . तथापि, एकल catch
ब्लॉक अपवाद निर्दिष्ट करू शकत नाही जे एकमेकांना वारसा देतात. दुसऱ्या शब्दांत, तुम्ही catch ( Exception
| RuntimeException
e) लिहू शकत नाही, कारण RuntimeException
वर्ग वारसा घेतो Exception
.
GO TO FULL VERSION