Lua - त्रुटि से निपटने
त्रुटि से निपटने की आवश्यकता है
वास्तविक दुनिया के संचालन में जटिल संचालन के उपयोग की आवश्यकता होती है, क्योंकि फ़ाइल संचालन, डेटाबेस लेनदेन और वेब सेवा कॉल में अक्सर त्रुटि से निपटने की आवश्यकता होती है।
किसी भी प्रोग्रामिंग में, त्रुटि से निपटने के लिए हमेशा एक आवश्यकता होती है। त्रुटियां दो प्रकार की हो सकती हैं जिनमें शामिल हैं,
- सिंटैक्स त्रुटियां
- समय त्रुटियों को चलाएँ
सिंटेक्स त्रुटियां
सिंटैक्स त्रुटियां विभिन्न प्रोग्राम घटकों जैसे ऑपरेटरों और अभिव्यक्तियों के अनुचित उपयोग के कारण होती हैं। सिंटैक्स त्रुटि के लिए एक सरल उदाहरण नीचे दिखाया गया है।
a == 2
जैसा कि आप जानते हैं, एक एकल "बराबर" और डबल "बराबर" के उपयोग के बीच अंतर है। एक के बजाय दूसरे का उपयोग करने से त्रुटि हो सकती है। एक "बराबर" असाइनमेंट को संदर्भित करता है जबकि एक डबल "बराबर" तुलना करने के लिए संदर्भित करता है। इसी प्रकार, हमारे पास कार्यान्वयन के पूर्वनिर्धारित तरीके होने के भाव और कार्य हैं।
सिंटैक्स त्रुटि के लिए एक और उदाहरण नीचे दिखाया गया है -
for a= 1,10
print(a)
end
जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेंगे -
lua: test2.lua:2: 'do' expected near 'print'
सिंटैक्स त्रुटियां रन टाइम त्रुटियों की तुलना में बहुत आसान हैं क्योंकि, Lua दुभाषिया रनटाइम त्रुटि के मामले में त्रुटि को अधिक स्पष्ट रूप से रेखांकित करता है। उपरोक्त त्रुटि से, हम आसानी से जान सकते हैं कि Lua संरचना के अनुसार प्रिंट स्टेटमेंट से पहले do स्टेटमेंट जोड़ना आवश्यक है।
रन टाइम एरर्स
रनटाइम त्रुटियों के मामले में, कार्यक्रम सफलतापूर्वक निष्पादित होता है, लेकिन इसके परिणामस्वरूप इनपुट या गलत कार्यों में गलतियों के कारण रनटाइम त्रुटियां हो सकती हैं। रन टाइम त्रुटि दिखाने के लिए एक सरल उदाहरण नीचे दिखाया गया है।
function add(a,b)
return a+b
end
add(10)
जब हम प्रोग्राम का निर्माण करेंगे, तो यह सफलतापूर्वक बनेगा और चलेगा। एक बार जब यह चलता है, तो रन टाइम एरर दिखाता है।
lua: test2.lua:2: attempt to perform arithmetic on local 'b' (a nil value)
stack traceback:
test2.lua:2: in function 'add'
test2.lua:5: in main chunk
[C]: ?
यह एक रनटाइम त्रुटि है, जो दो चर पास नहीं करने के कारण हुई थी। b पैरामीटर अपेक्षित है और यहाँ यह शून्य है और एक त्रुटि पैदा करता है।
जोर और त्रुटि कार्य
त्रुटियों को संभालने के लिए, हम अक्सर दो कार्यों का उपयोग करते हैं - assert तथा error। एक सरल उदाहरण नीचे दिखाया गया है।
local function add(a,b)
assert(type(a) == "number", "a is not a number")
assert(type(b) == "number", "b is not a number")
return a+b
end
add(10)
जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न त्रुटि आउटपुट मिलेगा।
lua: test2.lua:3: b is not a number
stack traceback:
[C]: in function 'assert'
test2.lua:3: in function 'add'
test2.lua:6: in main chunk
[C]: ?
error (message [, level])अंतिम संरक्षित फ़ंक्शन को कॉल करता है और संदेश को त्रुटि संदेश के रूप में देता है। यह फ़ंक्शन त्रुटि कभी नहीं लौटती है। आमतौर पर, त्रुटि संदेश की शुरुआत में त्रुटि स्थिति के बारे में कुछ जानकारी जोड़ती है। स्तर तर्क निर्दिष्ट करता है कि त्रुटि स्थिति कैसे प्राप्त करें। स्तर 1 (डिफ़ॉल्ट) के साथ, त्रुटि की स्थिति वह है जहां त्रुटि फ़ंक्शन कहा जाता था। स्तर 2 त्रुटि को इंगित करता है जहां फ़ंक्शन जिसे त्रुटि कहा जाता है; और इसी तरह। एक स्तर 0 पास करना संदेश में त्रुटि स्थिति की जानकारी के अलावा से बचा जाता है।
pcall और xpcall
लुआ प्रोग्रामिंग में, इन त्रुटियों को फेंकने और त्रुटियों को संभालने से बचने के लिए, हमें फ़ंक्शन फ़ंक्शन का उपयोग करने की आवश्यकता है।
pcall (f, arg1, ...)फ़ंक्शन अनुरोधित फ़ंक्शन को संरक्षित मोड में कॉल करता है। यदि फ़ंक्शन में कुछ त्रुटि होती है, तो यह एक त्रुटि नहीं है। यह सिर्फ त्रुटि की स्थिति देता है। Pcall का उपयोग करके एक सरल उदाहरण नीचे दिखाया गया है।
function myfunction ()
n = n/nil
end
if pcall(myfunction) then
print("Success")
else
print("Failure")
end
जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेगा।
Failure
xpcall (f, err)फ़ंक्शन अनुरोधित फ़ंक्शन को कॉल करता है और त्रुटि हैंडलर भी सेट करता है। F के अंदर कोई त्रुटि प्रचारित नहीं है; इसके बजाय, xpcall त्रुटि को पकड़ता है, मूल त्रुटि ऑब्जेक्ट के साथ गलत फ़ंक्शन को कॉल करता है, और एक स्थिति कोड देता है।
Xpcall के लिए एक सरल उदाहरण नीचे दिखाया गया है।
function myfunction ()
n = n/nil
end
function myerrorhandler( err )
print( "ERROR:", err )
end
status = xpcall( myfunction, myerrorhandler )
print( status)
जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेगा।
ERROR: test2.lua:2: attempt to perform arithmetic on global 'n' (a nil value)
false
एक प्रोग्रामर के रूप में, यह सुनिश्चित करना सबसे महत्वपूर्ण है कि आप अपने लिखे गए कार्यक्रमों में उचित त्रुटि से निपटने का ध्यान रखें। त्रुटि हैंडलिंग का उपयोग यह सुनिश्चित कर सकता है कि सीमा के परे अप्रत्याशित परिस्थितियों को प्रोग्राम के उपयोगकर्ता को परेशान किए बिना नियंत्रित किया जाए।