C ++ अपवाद हैंडलिंग
एक अपवाद एक समस्या है जो एक कार्यक्रम के निष्पादन के दौरान उत्पन्न होती है। C ++ अपवाद एक असाधारण परिस्थिति की प्रतिक्रिया है जो किसी प्रोग्राम को चलाने के दौरान उत्पन्न होती है, जैसे कि शून्य से विभाजित करने का प्रयास।
अपवाद प्रोग्राम के एक भाग से दूसरे में नियंत्रण स्थानांतरित करने का एक तरीका प्रदान करते हैं। C ++ अपवाद हैंडलिंग तीन कीवर्ड पर बनाया गया है:try, catch, तथा throw।
throw- जब कोई समस्या दिखाई देती है तो एक प्रोग्राम एक अपवाद को फेंक देता है। यह एक का उपयोग करके किया जाता हैthrow कीवर्ड।
catch- एक कार्यक्रम एक अपवाद हैंडलर के साथ एक अपवाद को एक कार्यक्रम में उस स्थान पर पकड़ता है जहां आप समस्या को संभालना चाहते हैं। catch कीवर्ड अपवाद को पकड़ने का संकेत देता है।
try - ए tryब्लॉक कोड की पहचान करता है जिसके लिए विशेष अपवाद सक्रिय किए जाएंगे। इसके बाद एक या अधिक कैच ब्लॉक होते हैं।
मान लें कि एक ब्लॉक एक अपवाद को बढ़ाएगा, एक विधि एक संयोजन का उपयोग करके एक अपवाद को पकड़ती है try तथा catchकीवर्ड। कोड के आसपास एक कोशिश / कैच ब्लॉक रखा गया है जो एक अपवाद उत्पन्न कर सकता है। एक कोशिश / कैच ब्लॉक के भीतर कोड को संरक्षित कोड के रूप में संदर्भित किया जाता है, और निम्नानुसार कोशिश / कैच का उपयोग करने के लिए वाक्यविन्यास -
try {
// protected code
} catch( ExceptionName e1 ) {
// catch block
} catch( ExceptionName e2 ) {
// catch block
} catch( ExceptionName eN ) {
// catch block
}
आप कई को सूचीबद्ध कर सकते हैं catch अपने मामले में विभिन्न प्रकार के अपवादों को पकड़ने के लिए बयान try ब्लॉक विभिन्न स्थितियों में एक से अधिक अपवाद उठाता है।
अपवाद फेंकना
अपवाद का उपयोग करके कोड ब्लॉक के भीतर कहीं भी फेंका जा सकता है throwबयान। थ्रो स्टेटमेंट का संचालक अपवाद के लिए एक प्रकार निर्धारित करता है और कोई भी अभिव्यक्ति हो सकती है और अभिव्यक्ति के परिणाम का प्रकार फेंके गए अपवाद के प्रकार को निर्धारित करता है।
शून्य स्थिति से विभाजित होने पर अपवाद फेंकने का एक उदाहरण निम्नलिखित है -
double division(int a, int b) {
if( b == 0 ) {
throw "Division by zero condition!";
}
return (a/b);
}
पकड़ने के अपवाद
catch ब्लॉक के बाद tryब्लॉक किसी भी अपवाद को पकड़ता है। आप यह निर्दिष्ट कर सकते हैं कि आप किस प्रकार के अपवाद को पकड़ना चाहते हैं और यह उस अपवाद घोषणा से निर्धारित होता है जो कीवर्ड पकड़ के बाद कोष्ठक में दिखाई देती है।
try {
// protected code
} catch( ExceptionName e ) {
// code to handle ExceptionName exception
}
उपरोक्त कोड इसके अपवाद को पकड़ लेगा ExceptionNameप्रकार। यदि आप यह निर्दिष्ट करना चाहते हैं कि कैच ब्लॉक को किसी भी प्रकार के अपवाद को संभालने की कोशिश करनी चाहिए जो कि एक कोशिश ब्लॉक में डाली गई है, तो आपको एक दीर्घवृत्त डालनी चाहिए, ..., कोष्ठक के बीच अपवाद घोषणा को संलग्न करते हुए -
try {
// protected code
} catch(...) {
// code to handle any exception
}
निम्नलिखित एक उदाहरण है, जो शून्य अपवाद द्वारा एक विभाजन को फेंकता है और हम इसे पकड़ ब्लॉक में पकड़ते हैं।
#include <iostream>
using namespace std;
double division(int a, int b) {
if( b == 0 ) {
throw "Division by zero condition!";
}
return (a/b);
}
int main () {
int x = 50;
int y = 0;
double z = 0;
try {
z = division(x, y);
cout << z << endl;
} catch (const char* msg) {
cerr << msg << endl;
}
return 0;
}
क्योंकि हम एक प्रकार का अपवाद उठा रहे हैं const char*, इसलिए इस अपवाद को पकड़ने के दौरान, हमें कैच ब्लॉक में कास्ट चार * का उपयोग करना होगा। यदि हम कोड को संकलित और चलाते हैं, तो यह निम्नलिखित परिणाम देगा -
Division by zero condition!
C ++ मानक अपवाद
C ++ में परिभाषित मानक अपवादों की एक सूची प्रदान करता है <exception>जिसका उपयोग हम अपने कार्यक्रमों में कर सकते हैं। इन्हें नीचे दिखाए गए एक अभिभावक-बच्चे वर्ग पदानुक्रम में व्यवस्थित किया गया है -
यहाँ उपरोक्त पदानुक्रम में उल्लिखित प्रत्येक अपवाद का छोटा विवरण दिया गया है -
अनु क्रमांक | अपवाद और विवरण |
---|---|
1 | std::exception सभी मानक C ++ अपवादों का एक अपवाद और मूल वर्ग। |
2 | std::bad_alloc इससे फेंका जा सकता है new। |
3 | std::bad_cast इससे फेंका जा सकता है dynamic_cast। |
4 | std::bad_exception यह C ++ प्रोग्राम में अप्रत्याशित अपवादों को संभालने के लिए उपयोगी उपकरण है। |
5 | std::bad_typeid इससे फेंका जा सकता है typeid। |
6 | std::logic_error एक अपवाद जो सैद्धांतिक रूप से कोड को पढ़कर पता लगाया जा सकता है। |
7 | std::domain_error यह एक अपवाद है जब गणितीय रूप से अमान्य डोमेन का उपयोग किया जाता है। |
8 | std::invalid_argument यह अमान्य तर्कों के कारण फेंका गया है। |
9 | std::length_error यह तब फेंका जाता है जब बहुत बड़ा std :: string बनाया जाता है। |
10 | std::out_of_range यह 'एट' विधि द्वारा फेंका जा सकता है, उदाहरण के लिए एक std :: वेक्टर और std :: बिटसेट <> :: ऑपरेटर [] ()। |
1 1 | std::runtime_error एक अपवाद जो सैद्धांतिक रूप से कोड को पढ़कर पता नहीं लगाया जा सकता है। |
12 | std::overflow_error यह एक गणितीय अतिप्रवाह होने पर फेंका जाता है। |
13 | std::range_error यह तब होता है जब आप किसी मान को संग्रहीत करने का प्रयास करते हैं जो सीमा से बाहर है। |
14 | std::underflow_error यदि गणितीय अंतर्प्रवाह होता है तो इसे फेंक दिया जाता है। |
नए अपवादों को परिभाषित करें
आप अपने स्वयं के अपवादों को विरासत में और ओवरराइड करके परिभाषित कर सकते हैं exceptionवर्ग की कार्यक्षमता। निम्नलिखित उदाहरण है, जो दिखाता है कि आप मानक तरीके से अपने स्वयं के अपवाद को लागू करने के लिए std :: अपवाद वर्ग का उपयोग कैसे कर सकते हैं -
#include <iostream>
#include <exception>
using namespace std;
struct MyException : public exception {
const char * what () const throw () {
return "C++ Exception";
}
};
int main() {
try {
throw MyException();
} catch(MyException& e) {
std::cout << "MyException caught" << std::endl;
std::cout << e.what() << std::endl;
} catch(std::exception& e) {
//Other errors
}
}
यह निम्नलिखित परिणाम का उत्पादन करेगा -
MyException caught
C++ Exception
यहाँ, what()एक सार्वजनिक विधि है जो अपवाद वर्ग द्वारा प्रदान की जाती है और इसे सभी बच्चे अपवाद कक्षाओं द्वारा ओवरराइड किया गया है। यह एक अपवाद का कारण देता है।