एफ # - घटनाएँ
घटनाएँ कक्षाओं को एक दूसरे के बीच संदेश भेजने और प्राप्त करने की अनुमति देती हैं।
GUI में, ईवेंट उपयोगकर्ता की क्रियाओं जैसे कि की प्रेस, क्लिक, माउस मूवमेंट, आदि या कुछ उत्पन्न होती हैं जैसे सिस्टम जनरेटेड नोटिफिकेशन। एप्लिकेशन को होने वाली घटनाओं पर प्रतिक्रिया देने की आवश्यकता होती है। उदाहरण के लिए, व्यवधान। घटनाओं का उपयोग अंतर-प्रक्रिया संचार के लिए किया जाता है।
वस्तुएं एक दूसरे के साथ समकालिक संदेश के माध्यम से संवाद करती हैं।
कार्यक्रम अन्य कार्यों से जुड़े होते हैं; ऑब्जेक्ट रजिस्टर होते हैंcallback किसी ईवेंट के फ़ंक्शंस और इन कॉलबैक को तब निष्पादित किया जाता है जब (और यदि) ईवेंट को किसी ऑब्जेक्ट द्वारा ट्रिगर किया जाता है।
इवेंट क्लास और इवेंट मॉड्यूल
Control.Event <'T> क्लास एक ऑब्जर्वेबल ऑब्जेक्ट या ईवेंट बनाने में मदद करता है।
घटनाओं के साथ काम करने के लिए इसके निम्न उदाहरण सदस्य हैं -
सदस्य | विवरण |
---|---|
प्रकाशित करना | प्रथम श्रेणी के मूल्य के रूप में एक अवलोकन प्रकाशित करता है। |
उत्प्रेरक | दिए गए मापदंडों का उपयोग करते हुए एक अवलोकन ट्रिगर करता है। |
नियंत्रण.ईवेंट मॉड्यूल इवेंट स्ट्रीम के प्रबंधन के लिए कार्य प्रदान करता है -
मूल्य | विवरण |
---|---|
जोड़ें: ('T → यूनिट) → इवेंट <' Del, 'T> → यूनिट | दिए गए फ़ंक्शन को ट्रिगर होने पर हर बार दिए गए फ़ंक्शन को चलाता है। |
चुनें: ('T →' U विकल्प) → IEvent <'Del,' T> → IEvent <'U> | एक नया ईवेंट लौटाता है जो मूल ईवेंट से संदेशों के चयन पर फायर करता है। चयन फ़ंक्शन एक वैकल्पिक नए संदेश के लिए एक मूल संदेश लेता है। |
फ़िल्टर: ('T → बूल) → IEvent <' Del, 'T> → IEvent <' T> | एक नया ईवेंट देता है जो मूल ईवेंट को सुनता है और परिणामी ईवेंट को तभी ट्रिगर करता है जब इवेंट का तर्क दिए गए फ़ंक्शन को पास करता है। |
नक्शा: ('T →' U) → IEvent <'Del,' T> → IEvent <'U> | एक नया ईवेंट देता है जो दिए गए फ़ंक्शन द्वारा बदल दिए गए मानों को पार करता है। |
मर्ज: IEvent <'Del1,' T> → IEvent <'Del2,' T> → IEvent <'T> | जब इनपुट इवेंट्स में से किसी एक में आग लग जाती है तो आउटपुट इवेंट को फायर करता है। |
जोड़ीदार: IEvent <'Del,' T> → IEvent <'T *' T> | एक नया ईवेंट देता है जो इनपुट ईवेंट के दूसरे और बाद के ट्रिगर पर ट्रिगर होता है। Nth इनपुट ईवेंट का ट्रिगर तर्क से पास करता है N-1th तथा Nthएक जोड़ी के रूप में ट्रिगर। तक तर्क पहुंचाN-1th ट्रिगर को छिपी हुई आंतरिक अवस्था में आयोजित किया जाता है Nth ट्रिगरिंग होती है। |
विभाजन: ('T → बूल) → IEvent <' Del, 'T> → IEvent <' T> * IEvent </>> | एक नया ईवेंट लौटाता है, जो मूल ईवेंट को सुनता है और यदि परिणामित तर्कों के लिए विधेय का एप्लिकेशन सही लौटा है, तो पहला परिणामी ईवेंट ट्रिगर करता है और दूसरा ईवेंट यदि वह गलत है। |
स्कैन: ('U →' T → 'U) →' U → IEvent <'Del,' T> → IEvent </ u> | इनपुट इवेंट पर ट्रिगर किए गए क्रमिक मानों के लिए दिए गए संचय फ़ंक्शन को लागू करने के परिणामों से मिलकर एक नई घटना देता है। आंतरिक स्थिति का एक आइटम राज्य पैरामीटर के वर्तमान मूल्य को रिकॉर्ड करता है। आंतरिक राज्य संचय समारोह के निष्पादन के दौरान बंद नहीं होता है, इसलिए ध्यान रखा जाना चाहिए कि इनपुट IEvent एक साथ कई थ्रेड द्वारा ट्रिगर नहीं किया गया है। |
विभाजित: ('T → चॉइस <' U1, 'U2>) → IEvent <' Del, 'T> → IEvent <' U1> * IEvent <'U2> | एक नया ईवेंट लौटाता है जो मूल ईवेंट को सुनता है और यदि फ़ंक्शन तर्क के लिए फ़ंक्शन का अनुप्रयोग एक च्वाइस 1 ओएफ 2, और दूसरा ईवेंट च्वाइस 2 ओएफ 2 लौटाता है तो यह पहली परिणामी घटना को ट्रिगर करता है। |
घटनाएँ बनाना
घटनाओं के माध्यम से बनाया और उपयोग किया जाता है Eventकक्षा। ईवेंट कंस्ट्रक्टर का उपयोग ईवेंट बनाने के लिए किया जाता है।
उदाहरण
type Worker(name : string, shift : string) =
let mutable _name = name;
let mutable _shift = shift;
let nameChanged = new Event<unit>() (* creates event *)
let shiftChanged = new Event<unit>() (* creates event *)
member this.Name
with get() = _name
and set(value) = _name <- value
member this.Shift
with get() = _shift
and set(value) = _shift <- value
इसके बाद आपको सार्वजनिक सदस्य के रूप में नामांकित फ़ील्ड को उजागर करने की आवश्यकता होती है, ताकि सुनने वाले उस घटना पर हुक कर सकें जिसके लिए, आप इसका उपयोग करते हैं Publish घटना की संपत्ति -
type Worker(name : string, shift : string) =
let mutable _name = name;
let mutable _shift = shift;
let nameChanged = new Event<unit>() (* creates event *)
let shiftChanged = new Event<unit>() (* creates event *)
member this.NameChanged = nameChanged.Publish (* exposed event handler *)
member this.ShiftChanged = shiftChanged.Publish (* exposed event handler *)
member this.Name
with get() = _name
and set(value) = _name <- value
nameChanged.Trigger() (* invokes event handler *)
member this.Shift
with get() = _shift
and set(value) = _shift <- value
shiftChanged.Trigger() (* invokes event handler *)
इसके बाद, आप ईवेंट हैंडलर में कॉलबैक जोड़ते हैं। प्रत्येक ईवेंट हैंडलर में IEvent <'T> टाइप होता है, जो कई तरीके प्रदान करता है -
तरीका | विवरण |
---|---|
वैल ऐड: इवेंट :( 'टी → यूनिट) → यूनिट | घटना के लिए एक श्रोता समारोह जोड़ता है। घटना के निकाल दिए जाने पर श्रोता को आमंत्रित किया जाएगा। |
वैल एडहैंडलर: 'डेल → यूनिट | घटना के लिए एक हैंडलर प्रतिनिधि ऑब्जेक्ट जोड़ता है। एक हैंडलर को बाद में RemoveHandler का उपयोग करके हटाया जा सकता है। घटना के निकाल दिए जाने पर श्रोता को आमंत्रित किया जाएगा। |
वैल रिमांडहैंडलर: 'डेल → यूनिट | किसी ईवेंट श्रोता स्टोर से एक श्रोता प्रतिनिधि को निकालता है। |
निम्नलिखित अनुभाग एक पूर्ण उदाहरण प्रदान करता है।
उदाहरण
निम्नलिखित उदाहरण उपरोक्त अवधारणा और तकनीकों को प्रदर्शित करता है -
type Worker(name : string, shift : string) =
let mutable _name = name;
let mutable _shift = shift;
let nameChanged = new Event<unit>() (* creates event *)
let shiftChanged = new Event<unit>() (* creates event *)
member this.NameChanged = nameChanged.Publish (* exposed event handler *)
member this.ShiftChanged = shiftChanged.Publish (* exposed event handler *)
member this.Name
with get() = _name
and set(value) =
_name <- value
nameChanged.Trigger() (* invokes event handler *)
member this.Shift
with get() = _shift
and set(value) =
_shift <- value
shiftChanged.Trigger() (* invokes event handler *)
let wk = new Worker("Wilson", "Evening")
wk.NameChanged.Add(fun () -> printfn "Worker changed name! New name: %s" wk.Name)
wk.Name <- "William"
wk.NameChanged.Add(fun () -> printfn "-- Another handler attached to NameChanged!")
wk.Name <- "Bill"
wk.ShiftChanged.Add(fun () -> printfn "Worker changed shift! New shift: %s" wk.Shift)
wk.Shift <- "Morning"
wk.ShiftChanged.Add(fun () -> printfn "-- Another handler attached to ShiftChanged!")
wk.Shift <- "Night"
जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -
Worker changed name! New name: William
Worker changed name! New name: Bill
-- Another handler attached to NameChanged!
Worker changed shift! New shift: Morning
Worker changed shift! New shift: Night
-- Another handler attached to ShiftChanged!