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

एक प्रोग्रामर के रूप में, यह सुनिश्चित करना सबसे महत्वपूर्ण है कि आप अपने लिखे गए कार्यक्रमों में उचित त्रुटि से निपटने का ध्यान रखें। त्रुटि हैंडलिंग का उपयोग यह सुनिश्चित कर सकता है कि सीमा के परे अप्रत्याशित परिस्थितियों को प्रोग्राम के उपयोगकर्ता को परेशान किए बिना नियंत्रित किया जाए।