एर्लैंग - अपवाद
रनटाइम त्रुटियों को संभालने के लिए किसी भी प्रोग्रामिंग भाषा में अपवाद हैंडलिंग की आवश्यकता होती है ताकि आवेदन के सामान्य प्रवाह को बनाए रखा जा सके। अपवाद सामान्य रूप से अनुप्रयोग के सामान्य प्रवाह को बाधित करता है, यही कारण है कि हमें अपने आवेदन में अपवाद हैंडलिंग का उपयोग करने की आवश्यकता है।
आम तौर पर जब Erlang में कोई अपवाद या त्रुटि होती है, तो निम्न संदेश प्रदर्शित किया जाएगा।
{"init terminating in do_boot", {undef,[{helloworld,start,[],[]},
{init,start_it,1,[]},{init,start_em,1,[]}]}}
क्रैश डंप को लिखा जाएगा -
erl_crash.dump
init terminating in do_boot ()
एर्लैंग में, 3 प्रकार के अपवाद हैं -
Error - फोन करना erlang:error(Reason)वर्तमान प्रक्रिया में निष्पादन को समाप्त करेगा और जब आप इसे पकड़ते हैं तो उनके तर्कों के साथ बुलाए गए अंतिम कार्यों का एक स्टैक ट्रेस शामिल होगा। ये उस प्रकार के अपवाद हैं जो ऊपर रनटाइम त्रुटियों को भड़काते हैं।
Exists- दो प्रकार के निकास हैं: 'आंतरिक' बाहर निकलता है और 'बाहरी' बाहर निकलता है। फ़ंक्शन को कॉल करके आंतरिक निकास को ट्रिगर किया जाता हैexit/1और वर्तमान प्रक्रिया को इसके क्रियान्वयन को रोक दें। बाहरी निकास के साथ कहा जाता हैexit/2 और Erlang के समवर्ती पहलू में कई प्रक्रियाओं के साथ करना है।
Throw- थ्रो उन अपवादों का एक वर्ग है जो उन मामलों के लिए उपयोग किए जाते हैं जिन्हें प्रोग्रामर को संभालने की उम्मीद की जा सकती है। बाहर निकलने और त्रुटियों के साथ तुलना में, वे वास्तव में किसी भी 'दुर्घटना की प्रक्रिया नहीं करते हैं!' उनके पीछे इरादा है, लेकिन वे प्रवाह को नियंत्रित करते हैं। जब आप प्रोग्रामर से उन्हें संभालने की अपेक्षा करते हुए थ्रो का उपयोग करते हैं, तो आमतौर पर उनका उपयोग करके मॉड्यूल के भीतर उनके उपयोग को प्रलेखित करना एक अच्छा विचार है।
ए try ... catch आपको सफल मामले को संभालने के साथ-साथ त्रुटियों का सामना करते हुए अभिव्यक्ति का मूल्यांकन करने का एक तरीका है।
ट्राई कैच एक्सप्रेशन का सामान्य सिंटैक्स इस प्रकार है।
वाक्य - विन्यास
try Expression of
SuccessfulPattern1 [Guards] ->
Expression1;
SuccessfulPattern2 [Guards] ->
Expression2
catch
TypeOfError:ExceptionPattern1 ->
Expression3;
TypeOfError:ExceptionPattern2 ->
Expression4
end
बीच में अभिव्यक्ति try and ofकहा जाता है कि यह संरक्षित है। इसका मतलब है कि उस कॉल के भीतर होने वाले किसी भी प्रकार के अपवाद को पकड़ा जाएगा। बीच में पैटर्न और भावtry ... of and catch बिल्कुल उसी तरीके से व्यवहार करें जैसे कि ए case ... of।
अंत में, पकड़ने वाला हिस्सा - यहां, आप प्रतिस्थापित कर सकते हैं TypeOfErrorया तो त्रुटि, फेंक या बाहर निकलने के लिए, प्रत्येक संबंधित प्रकार के लिए जो हमने इस अध्याय में देखा है। यदि कोई प्रकार प्रदान नहीं किया जाता है, तो एक फेंक मान लिया जाता है।
एरलांग में कुछ त्रुटियां और त्रुटि कारण निम्नलिखित हैं -
त्रुटि | त्रुटि का प्रकार |
---|---|
badarg | बुरा तर्क। तर्क गलत डेटा प्रकार का है, या अन्यथा बुरी तरह से बनता है। |
badarith | एक अंकगणितीय अभिव्यक्ति में खराब तर्क। |
{Badmatch, वी} | एक मैच अभिव्यक्ति का मूल्यांकन विफल रहा। मान V का मिलान नहीं हुआ। |
function_clause | फ़ंक्शन कॉल का मूल्यांकन करते समय कोई मिलान फ़ंक्शन क्लॉज नहीं पाया जाता है। |
{Case_clause, वी} | केस की अभिव्यक्ति का मूल्यांकन करते समय कोई मिलान शाखा नहीं मिलती है। मान V का मिलान नहीं हुआ। |
यदि खंड | यदि कोई अभिव्यक्ति का मूल्यांकन करता है तो कोई भी सच्ची शाखा नहीं मिलती है। |
{Try_clause, वी} | एक कोशिश अभिव्यक्ति के अनुभाग का मूल्यांकन करते समय कोई मिलान शाखा नहीं मिलती है। मान V का मिलान नहीं हुआ। |
यूएनडीईएफ | फ़ंक्शन कॉल का मूल्यांकन करते समय फ़ंक्शन नहीं पाया जा सकता है। |
{Badfun, एफ} | एक मजेदार एफ के साथ कुछ गलत है |
{Badarity, एफ} | एक मजेदार तर्क की गलत संख्या पर लागू होता है। एफ मजेदार और तर्कों का वर्णन करता है। |
timeout_value | किसी प्राप्त में टाइमआउट मान..एक अभिव्यक्ति पूर्णांक या अनंत की तुलना में कुछ और के लिए मूल्यांकन किया जाता है। |
noproc | गैर-मौजूदा प्रक्रिया से लिंक करने की कोशिश कर रहा है। |
निम्नलिखित इस बात का उदाहरण है कि इन अपवादों का उपयोग कैसे किया जा सकता है और चीजें कैसे की जाती हैं।
पहला फ़ंक्शन अपवाद के सभी संभावित प्रकार उत्पन्न करता है।
फिर हम कॉल करने के लिए एक आवरण फ़ंक्शन लिखते हैं generate_exception एक कोशिश में ... अभिव्यक्ति को पकड़ने।
उदाहरण
-module(helloworld).
-compile(export_all).
generate_exception(1) -> a;
generate_exception(2) -> throw(a);
generate_exception(3) -> exit(a);
generate_exception(4) -> {'EXIT', a};
generate_exception(5) -> erlang:error(a).
demo1() ->
[catcher(I) || I <- [1,2,3,4,5]].
catcher(N) ->
try generate_exception(N) of
Val -> {N, normal, Val}
catch
throw:X -> {N, caught, thrown, X};
exit:X -> {N, caught, exited, X};
error:X -> {N, caught, error, X}
end.
demo2() ->
[{I, (catch generate_exception(I))} || I <- [1,2,3,4,5]].
demo3() ->
try generate_exception(5)
catch
error:X ->
{X, erlang:get_stacktrace()}
end.
lookup(N) ->
case(N) of
1 -> {'EXIT', a};
2 -> exit(a)
end.
अगर हम कार्यक्रम को हेलोवर्ल्ड: डेमो () के रूप में चलाते हैं। , हम निम्नलिखित उत्पादन मिलेगा -
उत्पादन
[{1,normal,a},
{2,caught,thrown,a},
{3,caught,exited,a},
{4,normal,{'EXIT',a}},
{5,caught,error,a}]