एफ # - अपवाद हैंडलिंग

एक अपवाद एक समस्या है जो एक कार्यक्रम के निष्पादन के दौरान उत्पन्न होती है। एक एफ # अपवाद एक असाधारण परिस्थिति की प्रतिक्रिया है जो किसी कार्यक्रम को चलाने के दौरान उत्पन्न होती है, जैसे कि शून्य से विभाजित करने का प्रयास।

अपवाद प्रोग्राम के एक भाग से दूसरे में नियंत्रण स्थानांतरित करने का एक तरीका प्रदान करते हैं। F # अपवाद हैंडलिंग निम्नलिखित निर्माण प्रदान करता है -

निर्माण विवरण
expr बढ़ा दिए गए अपवाद को उठाता है।
फेल होने के बावजूद उठाता है System.Exception अपवाद।
नियमों के साथ विस्तार करने का प्रयास करें पैटर्न नियमों से मेल खाती अभिव्यक्तियाँ।
समाप्ति समाप्ति का प्रयास करें निष्पादन finally अभिकलन सफल होने पर और अपवाद को उठाए जाने पर दोनों अभिव्यक्ति।
| : ArgumentException दिए गए .NET अपवाद प्रकार से मेल खाने वाला नियम।
| : ई के रूप में तर्क एक नियम। दिए गए .NET अपवाद प्रकार से मेल खाते हुए, नाम को बांधते हुए e अपवाद ऑब्जेक्ट मान के लिए।
| विफलता (संदेश) → expr दिए गए डेटा ले जाने वाले F # अपवाद से मेल खाने वाला नियम।
| exn → एक्सप्र एक नियम जो किसी अपवाद को मिलाता है, नाम को बांधता है exn अपवाद ऑब्जेक्ट मान के लिए।
| exn जब expr → expr एक नियम दिए गए शर्त के तहत अपवाद से मेल खाता है, नाम को बांधता है exn अपवाद ऑब्जेक्ट मान के लिए।

आइए हम अपवाद हैंडलिंग के मूल सिंटैक्स के साथ शुरू करें।

वाक्य - विन्यास

F # अपवाद हैंडलिंग ब्लॉक के लिए मूल सिंटैक्स है -

exception exception-type of argument-type

कहाँ पे,

  • exception-type एक नए F # अपवाद प्रकार का नाम है।

  • argument-type एक तर्क के प्रकार का प्रतिनिधित्व करता है जिसे आपूर्ति की जा सकती है जब आप इस प्रकार का अपवाद उठाते हैं।

  • तर्क-प्रकार के लिए टपल प्रकार का उपयोग करके कई तर्क निर्दिष्ट किए जा सकते हैं।

try...with अभिव्यक्ति का उपयोग F # भाषा में अपवाद हैंडलिंग के लिए किया जाता है।

अभिव्यक्ति के लिए ... के लिए सिंटैक्स है -

try
   expression1
with
   | pattern1 -> expression2
   | pattern2 -> expression3
...

try...finally अभिव्यक्ति आपको क्लीन-अप कोड निष्पादित करने की अनुमति देती है, भले ही कोड का एक ब्लॉक एक अपवाद फेंकता हो।

कोशिश के लिए सिंटैक्स ... आखिरकार अभिव्यक्ति है -

try
   expression1
finally
   expression2

raiseफ़ंक्शन का उपयोग यह इंगित करने के लिए किया जाता है कि कोई त्रुटि या असाधारण स्थिति उत्पन्न हुई है। यह अपवाद ऑब्जेक्ट में त्रुटि के बारे में जानकारी भी कैप्चर करता है।

वृद्धि समारोह के लिए सिंटैक्स है -

raise (expression)

failwith फ़ंक्शन एक F # अपवाद उत्पन्न करता है।

विफलता फ़ंक्शन के लिए सिंटैक्स है -

failwith error-message-string

invalidArg फ़ंक्शन एक तर्क अपवाद उत्पन्न करता है।

invalidArg parameter-name error-message-string

अपवाद हैंडलिंग का उदाहरण

उदाहरण 1

निम्नलिखित कार्यक्रम ब्लॉक के साथ एक साधारण प्रयास के साथ बुनियादी अपवाद को दर्शाता है -

let divisionprog x y =
   try
      Some (x / y)
   with
      | :? System.DivideByZeroException -> printfn "Division by zero!"; None

let result1 = divisionprog 100 0

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Division by zero!

उदाहरण 2

एफ # एक प्रदान करता है exceptionअपवाद घोषित करने के लिए टाइप करें। आप फ़िल्टर में सीधे एक अपवाद प्रकार का उपयोग कर सकते हैंtry...with अभिव्यक्ति।

निम्न उदाहरण यह प्रदर्शित करता है -

exception Error1 of string
// Using a tuple type as the argument type.
exception Error2 of string * int

let myfunction x y =
   try
      if x = y then raise (Error1("Equal Number Error"))
      else raise (Error2("Error Not detected", 100))
   with
      | Error1(str) -> printfn "Error1 %s" str
      | Error2(str, i) -> printfn "Error2 %s %d" str i
myfunction 20 10
myfunction 5 5

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Error2 Error Not detected 100
Error1 Equal Number Error

उदाहरण 3

निम्न उदाहरण नेस्टेड अपवाद हैंडलिंग को दर्शाता है -

exception InnerError of string
exception OuterError of string

let func1 x y =
   try
      try
         if x = y then raise (InnerError("inner error"))
         else raise (OuterError("outer error"))
      with
         | InnerError(str) -> printfn "Error:%s" str
   finally
      printfn "From the finally block."

let func2 x y =
   try
      func1 x y
   with
      | OuterError(str) -> printfn "Error: %s" str

func2 100 150
func2 100 100
func2 100 120

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

From the finally block.
Error: outer error
Error:inner error
From the finally block.
From the finally block.
Error: outer error

उदाहरण 4

निम्न कार्य दर्शाता है failwith कार्य -

let divisionFunc x y =
   if (y = 0) then failwith "Divisor cannot be zero."
   else
      x / y

let trydivisionFunc x y =
   try
      divisionFunc x y
   with
      | Failure(msg) -> printfn "%s" msg; 0

let result1 = trydivisionFunc 100 0
let result2 = trydivisionFunc 100 4
printfn "%A" result1
printfn "%A" result2

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Divisor cannot be zero.
0
25

उदाहरण 5

invalidArgफ़ंक्शन एक तर्क अपवाद उत्पन्न करता है। निम्नलिखित कार्यक्रम यह प्रदर्शित करता है -

let days = [| "Sunday"; "Monday"; "Tuesday"; "Wednesday"; "Thursday"; "Friday"; "Saturday" |]
let findDay day =
   if (day > 7 || day < 1)
      then invalidArg "day" (sprintf "You have entered %d." day)
   days.[day - 1]

printfn "%s" (findDay 1)
printfn "%s" (findDay 5)
printfn "%s" (findDay 9)

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Sunday
Thursday
Unhandled Exception:
System.ArgumentException: You have entered 9.
…

फ़ाइल और चर के बारे में कुछ अन्य जानकारी जो सिस्टम में त्रुटि है, सिस्टम के आधार पर भी प्रदर्शित की जाएगी।