इवेंट लूप: Difference between revisions
No edit summary |
|||
(3 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
[[ कंप्यूटर विज्ञान | कंप्यूटर विज्ञान]] में, इवेंट लूप प्रोग्रामिंग निर्माण या [[ सॉफ्टवेयर डिजाइन पैटर्न |सॉफ्टवेयर डिजाइन पैटर्न]] है जो [[ कंप्यूटर प्रोग्राम |कंप्यूटर प्रोग्राम]] में [[ घटना-संचालित प्रोग्रामिंग |घटना-संचालित प्रोग्रामिंग]] या [[ संदेश पासिंग इंटरफ़ेस |संदेश पासिंग इंटरफ़ेस]] की प्रतीक्षा करता है और भेजता है। ईवेंट लूप कुछ आंतरिक या बाहरी ईवेंट प्रदाता (जो सामान्यतः किसी ईवेंट के आने तक अनुरोध को अवरुद्ध ( | [[ कंप्यूटर विज्ञान | कंप्यूटर विज्ञान]] में, इवेंट लूप प्रोग्रामिंग निर्माण या [[ सॉफ्टवेयर डिजाइन पैटर्न |सॉफ्टवेयर डिजाइन पैटर्न]] है जो [[ कंप्यूटर प्रोग्राम |कंप्यूटर प्रोग्राम]] में [[ घटना-संचालित प्रोग्रामिंग |घटना-संचालित प्रोग्रामिंग]] या [[ संदेश पासिंग इंटरफ़ेस |संदेश पासिंग इंटरफ़ेस]] की प्रतीक्षा करता है और भेजता है। ईवेंट लूप कुछ आंतरिक या बाहरी ईवेंट प्रदाता (जो सामान्यतः किसी ईवेंट के आने तक अनुरोध को अवरुद्ध (कंप्यूटरीकृत) करता है) के लिए अनुरोध करके कार्य करता है, फिर संबंधित [[ आयोजन प्रबंधकर्ता |आयोजन प्रबंधकर्ता]] को कॉल करता है (इवेंट को डिस्पैच करता है)। ईवेंट लूप को कभी-कभी संदेश प्रेषक, संदेश लूप, संदेश पंप या रन लूप के रूप में भी जाना जाता है। | ||
ईवेंट-लूप का उपयोग [[ रिएक्टर पैटर्न |रिएक्टर पैटर्न]] के संयोजन के साथ किया जा सकता है, यदि ईवेंट प्रदाता फ़ाइल इंटरफ़ेस का अनुसरण करता है, जिसे चुना जा सकता है या 'पोल' किया जा सकता है (यूनिक्स सिस्टम कॉल, वास्तविक मतदान नहीं (कंप्यूटर विज्ञान)) होते हैं। ईवेंट लूप लगभग हमेशा संदेश प्रवर्तक के साथ अतुल्यकालिक रूप से संचालित होता है। | ईवेंट-लूप का उपयोग [[ रिएक्टर पैटर्न |रिएक्टर पैटर्न]] के संयोजन के साथ किया जा सकता है, यदि ईवेंट प्रदाता फ़ाइल इंटरफ़ेस का अनुसरण करता है, जिसे चुना जा सकता है या 'पोल' किया जा सकता है (यूनिक्स सिस्टम कॉल, वास्तविक मतदान नहीं (कंप्यूटर विज्ञान)) होते हैं। ईवेंट लूप लगभग हमेशा संदेश प्रवर्तक के साथ अतुल्यकालिक रूप से संचालित होता है। | ||
Line 10: | Line 10: | ||
== वैकल्पिक डिजाइन == | == वैकल्पिक डिजाइन == | ||
यह दृष्टिकोण कई अन्य विकल्पों के विपरीत है: | यह दृष्टिकोण कई अन्य विकल्पों के विपरीत है: | ||
*परंपरागत रूप से, कार्यक्रम केवल बार चलता है, फिर समाप्त हो जाता है। | *परंपरागत रूप से, कार्यक्रम केवल बार चलता है, फिर समाप्त हो जाता है। कंप्यूटरीकृत को शुरुआती दिनों में इस प्रकार का कार्यक्रम बहुत आम था, और इसमें किसी भी प्रकार की उपयोगकर्ता अन्तरक्रियाशीलता का अभाव था। यह अभी भी अधिकांशतः उपयोग किया जाता है, विशेष रूप से [[ कमांड लाइन |कमांड लाइन]] या कमांड-लाइन-संचालित प्रोग्राम के रूप में करते हैं। किसी भी [[ मापदंडों |मापदंडों]] को पहले से सेट किया जाता है और प्रोग्राम शुरू होने पर ही इसे पास कर दिया जाता है। | ||
* मेनू चालित डिजाइन में ये अभी भी मुख्य लूप को प्रस्तुत कर सकते हैं, लेकिन सामान्यतः सामान्य अर्थों में इवेंट-संचालित प्रोग्रामिंग के रूप में नहीं सोचा जाता है। इसके अतिरिक्त, उपयोगकर्ता को विकल्पों के कभी-संकीर्ण सेट के साथ प्रस्तुत किया जाता है जब तक कि वे जो कार्य करना चाहते हैं वह एकमात्र विकल्प उपलब्ध नहीं है। मेनू के माध्यम से सीमित | * मेनू चालित डिजाइन में ये अभी भी मुख्य लूप को प्रस्तुत कर सकते हैं, लेकिन सामान्यतः सामान्य अर्थों में इवेंट-संचालित प्रोग्रामिंग के रूप में नहीं सोचा जाता है। इसके अतिरिक्त, उपयोगकर्ता को विकल्पों के कभी-संकीर्ण सेट के साथ प्रस्तुत किया जाता है जब तक कि वे जो कार्य करना चाहते हैं वह एकमात्र विकल्प उपलब्ध नहीं है। मेनू के माध्यम से सीमित अन्तर क्रियाशीलता उपलब्ध है। | ||
== उपयोग == | == उपयोग == | ||
[[ ग्राफिकल यूज़र इंटरफ़ेस | ग्राफिकल यूज़र इंटरफ़ेस]] की प्रबलता के कारण, अधिकांश आधुनिक अनुप्रयोगों में मुख्य लूप होता है। <code>get_next_message()</code> रूटीन सामान्यतः ऑपरेटिंग सिस्टम द्वारा प्रदान किया जाता है, और संदेश उपलब्ध होने तक ब्लॉक ( | [[ ग्राफिकल यूज़र इंटरफ़ेस | ग्राफिकल यूज़र इंटरफ़ेस]] की प्रबलता के कारण, अधिकांश आधुनिक अनुप्रयोगों में मुख्य लूप होता है। <code>get_next_message()</code> रूटीन सामान्यतः ऑपरेटिंग सिस्टम द्वारा प्रदान किया जाता है, और संदेश उपलब्ध होने तक ब्लॉक (कंप्यूटरीकृत) किया जाता है। इस प्रकार, लूप केवल तभी दर्ज किया जाता है जब प्रक्रिया करने के लिए कुछ होता है। | ||
'''function''' main | '''function''' main | ||
Line 26: | Line 26: | ||
== फ़ाइल इंटरफ़ेस == | == फ़ाइल इंटरफ़ेस == | ||
[[ यूनिक्स | यूनिक्स]] के अनुसार, सब कुछ फ़ाइल प्रतिमान है जो स्वाभाविक रूप से फ़ाइल-आधारित ईवेंट लूप की ओर ले जाता है। फाइलों से पढ़ना और लिखना, अंतर-प्रक्रिया संचार, नेटवर्क संचार, और डिवाइस नियंत्रण सभी फ़ाइल I/O का उपयोग करके | [[ यूनिक्स | यूनिक्स]] के अनुसार, सब कुछ फ़ाइल प्रतिमान है जो स्वाभाविक रूप से फ़ाइल-आधारित ईवेंट लूप की ओर ले जाता है। फाइलों से पढ़ना और लिखना, अंतर-प्रक्रिया संचार, नेटवर्क संचार, और डिवाइस नियंत्रण सभी फ़ाइल I/O का उपयोग करके फ़ाइल डिस्क्रिप्टर द्वारा पहचाने गए लक्ष्य के साथ प्राप्त किए जाते हैं। सेलेक्ट (यूनिक्स) और [[ मतदान (यूनिक्स) |मतदान (यूनिक्स)]] सिस्टम कॉल [[ फाइल डिस्क्रिप्टर |फाइल डिस्क्रिप्टर]] के सेट को स्थिति में बदलाव के लिए मॉनिटर करने की अनुमति देते हैं, उदाहरण के लिए जब डेटा पढ़ने के लिए उपलब्ध हो जाता है। | ||
उदाहरण के लिए, प्रोग्राम पर विचार करें जो निरंतर अद्यतन फ़ाइल से पढ़ता है और [[ एक्स विंडो सिस्टम |एक्स विंडो सिस्टम]] में इसकी सामग्री प्रदर्शित करता है, जो क्लाइंट के साथ सॉकेट (या तो [[ यूनिक्स डोमेन सॉकेट |यूनिक्स डोमेन सॉकेट]] या [[ बर्कले सॉकेट |बर्कले सॉकेट]] ) पर संचार करता है | उदाहरण के लिए, प्रोग्राम पर विचार करें जो निरंतर अद्यतन फ़ाइल से पढ़ता है और [[ एक्स विंडो सिस्टम |एक्स विंडो सिस्टम]] में इसकी सामग्री प्रदर्शित करता है, जो क्लाइंट के साथ सॉकेट (या तो [[ यूनिक्स डोमेन सॉकेट |यूनिक्स डोमेन सॉकेट]] या [[ बर्कले सॉकेट |बर्कले सॉकेट]] ) पर संचार करता है | ||
Line 44: | Line 44: | ||
=== संकेतों को संभालना === | === संकेतों को संभालना === | ||
यूनिक्स में कुछ चीजों में से जो फ़ाइल इंटरफ़ेस के अनुरूप नहीं है, अतुल्यकालिक घटनाएँ ([[ संकेत (कंप्यूटिंग) ]]) हैं। [[ सिग्नल हैंडलर |सिग्नल हैंडलर]] में सिग्नल प्राप्त होते हैं, कोड के छोटे, सीमित टुकड़े जो चलते हैं जबकि शेष कार्य निलंबित रहता है | यूनिक्स में कुछ चीजों में से जो फ़ाइल इंटरफ़ेस के अनुरूप नहीं है, अतुल्यकालिक घटनाएँ ([[ संकेत (कंप्यूटिंग) | संकेत (कंप्यूटरीकृत)]] ) हैं। [[ सिग्नल हैंडलर |सिग्नल हैंडलर]] में सिग्नल प्राप्त होते हैं, कोड के छोटे, सीमित टुकड़े जो चलते हैं जबकि शेष कार्य निलंबित रहता है, यदि कार्य अवरुद्ध होने पर संकेत प्राप्त होता है और <code>select()</code> द्वारा नियंत्रित किया जाता है , [[ लिनक्स में त्रुटि कोड |लिनक्स में त्रुटि कोड]] के साथ चयन जल्दी वापस आ जाएगा, यदि कार्य सीपीयू बाउंड होने के समय संकेत प्राप्त होता है, तो सिग्नल हैंडलर के वापस आने तक कार्य को निर्देशों के बीच निलंबित कर दिया जाएगा। | ||
इस प्रकार संकेतों को संभालने का स्पष्ट तरीका सिग्नल संचालकों के लिए वैश्विक ध्वज सेट करना है और ध्वज के लिए इवेंट लूप की जांच तुरंत पहले और बाद में करना है। यदि यह सेट है तो | इस प्रकार संकेतों को संभालने का स्पष्ट तरीका सिग्नल संचालकों के लिए वैश्विक ध्वज सेट करना है और ध्वज के लिए इवेंट लूप की जांच तुरंत पहले और बाद में करना है। यदि यह सेट है तो <code>select()</code> काल करके सिग्नल को उसी प्रकार से संभालें जैसे फ़ाइल डिस्क्रिप्टर पर ईवेंट के साथ करते हैं। दुर्भाग्य से, यह [[ दौड़ की स्थिति |दौड़ की स्थिति]] को जन्म देता है: यदि फ्लैग की जांच और कॉल करने के बीच तुरंत संकेत आता है <code>select()</code>, इसे तब तक संभाला नहीं जाएगा <code>select()</code> किसी अन्य कारण से लौटाता है (उदाहरण के लिए, निराश उपयोगकर्ता द्वारा बाधित किया जाना)। | ||
[[ POSIX | पासिक्स]] द्वारा निकाला गया समाधान है <code>[[pselect]]()</code> कॉल, जो समान है <code>select()</code> लेकिन अतिरिक्त लेता है <code>sigmask</code> पैरामीटर, जो सिग्नल मास्क का वर्णन करता है। यह एप्लिकेशन को मुख्य कार्य में सिग्नल को मास्क करने की अनुमति देता है, फिर की अवधि के लिए मास्क को हटा दें <code>select()</code> कॉल ऐसे करें कि सिग्नल हैंडलर को केवल तभी बुलाया जाए जब एप्लिकेशन I/O बाध्य हो। चूंकि, का कार्यान्वयन <code>pselect()</code> हमेशा विश्वसनीय नहीं रहे हैं | [[ POSIX | पासिक्स]] द्वारा निकाला गया समाधान है <code>[[pselect]]()</code> कॉल, जो समान है <code>select()</code> लेकिन अतिरिक्त लेता है <code>sigmask</code> पैरामीटर, जो सिग्नल मास्क का वर्णन करता है। यह एप्लिकेशन को मुख्य कार्य में सिग्नल को मास्क करने की अनुमति देता है, फिर की अवधि के लिए मास्क को हटा दें <code>select()</code> कॉल ऐसे करें कि सिग्नल हैंडलर को केवल तभी बुलाया जाए जब एप्लिकेशन I/O बाध्य हो। चूंकि, का कार्यान्वयन <code>pselect()</code> हमेशा विश्वसनीय नहीं रहे हैं, 2.6.16 से पहले के लाइनेक्स के संस्करणों में a नहीं है <code>pselect()</code> सिस्टम कॉल,<ref>{{Cite web|title=Linux_2_6_16 - Linux कर्नेल Newbies|url=https://kernelnewbies.org/Linux_2_6_16|access-date=2021-03-03|website=kernelnewbies.org}}</ref> [[ glibc |glibc]] को ही दौड़ की स्थिति के लिए प्रवण विधि के माध्यम से इसका अनुकरण करने के लिए मजबूर करना <code>pselect()</code> बचने का है। | ||
एक वैकल्पिक, अधिक पोर्टेबल समाधान, अतुल्यकालिक घटनाओं को स्व-पाइप चाल का उपयोग करके फ़ाइल-आधारित घटनाओं में परिवर्तित करना है,<ref>{{cite web |url=http://cr.yp.to/docs/selfpipe.html |title=सेल्फ-पाइप ट्रिक|author=D. J. Bernstein }}</ref> जहां सिग्नल हैंडलर पाइप को बाइट लिखता है जिसके दूसरे सिरे की जाँच की जाती है <code>select()</code> मुख्य कार्यक्रम में।<ref>BUGS, {{man|2|pselect|Linux|synchronous I/O multiplexing}}</ref> [[ लिनक्स कर्नेल |लिनक्स कर्नेल]] संस्करण 2.6.22 में, नया सिस्टम कॉल <code>signalfd()</code> जोड़ा गया, जो विशेष फाइल डिस्क्रिप्टर के माध्यम से सिग्नल प्राप्त करने की अनुमति देता है। | एक वैकल्पिक, अधिक पोर्टेबल समाधान, अतुल्यकालिक घटनाओं को स्व-पाइप चाल का उपयोग करके फ़ाइल-आधारित घटनाओं में परिवर्तित करना है,<ref>{{cite web |url=http://cr.yp.to/docs/selfpipe.html |title=सेल्फ-पाइप ट्रिक|author=D. J. Bernstein }}</ref> जहां सिग्नल हैंडलर पाइप को बाइट लिखता है जिसके दूसरे सिरे की जाँच की जाती है <code>select()</code> मुख्य कार्यक्रम में।<ref>BUGS, {{man|2|pselect|Linux|synchronous I/O multiplexing}}</ref> [[ लिनक्स कर्नेल |लिनक्स कर्नेल]] संस्करण 2.6.22 में, नया सिस्टम कॉल <code>signalfd()</code> जोड़ा गया, जो विशेष फाइल डिस्क्रिप्टर के माध्यम से सिग्नल प्राप्त करने की अनुमति देता है। | ||
Line 56: | Line 56: | ||
=== विंडोज़ अनुप्रयोग === | === विंडोज़ अनुप्रयोग === | ||
{{Main|माइक्रोसाफ्ट विंडोज में मेसेज लूप}} | {{Main|माइक्रोसाफ्ट विंडोज में मेसेज लूप}} | ||
[[ Microsoft Windows | माइक्रोसाफ्ट विंडोज]] ऑपरेटिंग सिस्टम पर, प्रक्रिया जो उपयोगकर्ता के साथ इंटरैक्ट करती है उसे आने वाले संदेशों को स्वीकार करना और प्रतिक्रिया देना चाहिए, जो उस प्रक्रिया में [[ Microsoft Windows में संदेश लूप |माइक्रोसाफ्ट विंडोज में संदेश लूप]] द्वारा लगभग अनिवार्य रूप से किया जाता है। विंडोज़ में, संदेश ऑपरेटिंग सिस्टम पर निर्मित और लगाए गए ईवेंट के बराबर होता है। घटना अन्य लोगों के बीच उपयोगकर्ता इंटरैक्शन, नेटवर्क ट्रैफ़िक, सिस्टम प्रोसेसिंग, टाइमर गतिविधि, इंटर | [[ Microsoft Windows | माइक्रोसाफ्ट विंडोज]] ऑपरेटिंग सिस्टम पर, प्रक्रिया जो उपयोगकर्ता के साथ इंटरैक्ट करती है उसे आने वाले संदेशों को स्वीकार करना और प्रतिक्रिया देना चाहिए, जो उस प्रक्रिया में [[ Microsoft Windows में संदेश लूप |माइक्रोसाफ्ट विंडोज में संदेश लूप]] द्वारा लगभग अनिवार्य रूप से किया जाता है। विंडोज़ में, संदेश ऑपरेटिंग सिस्टम पर निर्मित और लगाए गए ईवेंट के बराबर होता है। घटना अन्य लोगों के बीच उपयोगकर्ता इंटरैक्शन, नेटवर्क ट्रैफ़िक, सिस्टम प्रोसेसिंग, टाइमर गतिविधि, इंटर प्रक्रिया में संचरित हो सकती है। गैर-संवादात्मक, I/O केवल ईवेंट के लिए, विंडोज में इनपुट/आउटपुट समापन पोर्ट|I/O पूर्णता पोर्ट हैं। I/O समापन पोर्ट लूप संदेश लूप से अलग से चलते हैं, और बॉक्स के बाहर संदेश लूप से इंटरैक्ट नहीं करते हैं। | ||
अधिकांश [[ Win32 | | अधिकांश [[ Win32 |विन32]] [[ अनुप्रयोग प्रक्रिया सामग्री |अनुप्रयोग प्रक्रिया सामग्री]] का दिल [https://msdn.microsoft.com/en-us/library/ms633559.aspx WinMain()] फ़ंक्शन है, जो [https://msdn.microsoft.com/en- us/library/ms644936.aspx GetMessage()] लूप में। GetMessage() संदेश या ईवेंट प्राप्त होने तक ब्लॉक करता है (फ़ंक्शन के साथ [https://msdn.microsoft.com/en-us/library/ms644943.aspx PeekMessage()] गैर-अवरुद्ध विकल्प के रूप में)। कुछ वैकल्पिक प्रसंस्करण के बाद, यह [https://msdn.microsoft.com/en-us/library/ms644934.aspx DispatchMessage()] को कॉल करेगा, जो प्रासंगिक हैंडलर को संदेश भेजता है, जिसे [[ विंडोप्रोक |विंडोप्रोक]] भी कहा जाता है। सामान्यतः, जिन संदेशों में कोई विशेष [https://msdn.microsoft.com/en-us/library/ms633573.aspx WindowProc()] नहीं होता है, उन्हें WindowProc Default_processing, डिफ़ॉल्ट रूप से भेजा जाता है। DispatchMessage() संदेश के [[ HWND |एचडब्ल्यूएनडी]] [[ स्मार्ट सूचक |स्मार्ट सूचक]] के विंडोप्रोक को कॉल करता है ([https://msdn.microsoft.com/en-us/library/ms633586.aspx RegisterClass()] फ़ंक्शन के साथ पंजीकृत)। | ||
==== संदेश आदेश ==== | ==== संदेश आदेश ==== | ||
माइक्रोसाफ्ट विंडोज के अधिक हाल के संस्करण प्रोग्रामर को गारंटी देते हैं कि संदेशों को एप्लिकेशन के संदेश लूप में वितरित किया जाएगा जिससे कि वे सिस्टम और उसके बाह्य उपकरणों द्वारा देखे जा सकें। [[ थ्रेड (कंप्यूटिंग) |थ्रेड ( | माइक्रोसाफ्ट विंडोज के अधिक हाल के संस्करण प्रोग्रामर को गारंटी देते हैं कि संदेशों को एप्लिकेशन के संदेश लूप में वितरित किया जाएगा जिससे कि वे सिस्टम और उसके बाह्य उपकरणों द्वारा देखे जा सकें। [[ थ्रेड (कंप्यूटिंग) |थ्रेड (कंप्यूटरीकृत)]] अनुप्रयोगों के डिज़ाइन परिणामों पर विचार करते समय यह गारंटी आवश्यक है। चूंकि, कुछ संदेशों के अलग-अलग नियम होते हैं, जैसे संदेश या भिन्न दस्तावेजी प्राथमिकता वाले संदेश जो हमेशा अंतिम रूप से प्राप्त होते हैं।<ref>[https://msdn.microsoft.com/en-us/library/ms644936.aspx GetMessage() function] with message priority list.</ref> | ||
=== एक्स विंडो सिस्टम === | === एक्स विंडो सिस्टम === | ||
==== [[ एक्सलिब | एक्सलिब]] इवेंट लूप ==== | ==== [[ एक्सलिब | एक्सलिब]] इवेंट लूप ==== | ||
X विंडो सिस्टम एप्लिकेशन सीधे Xlib का उपयोग कर के चारों ओर बनाया गया है <code>XNextEvent</code> कार्यों का परिवार | X विंडो सिस्टम एप्लिकेशन सीधे Xlib का उपयोग कर के चारों ओर बनाया गया है <code>XNextEvent</code> कार्यों का परिवार, <code>XNextEvent</code> ईवेंट क्यू पर कोई ईवेंट दिखाई देने तक ब्लॉक करता है, जिसके बाद एप्लिकेशन इसे उचित रूप से संसाधित करता है। Xlib इवेंट लूप केवल विंडो सिस्टम इवेंट्स को हैंडल करता है, जिन अनुप्रयोगों को अन्य फ़ाइलों और उपकरणों पर प्रतीक्षा करने में सक्षम होने की आवश्यकता होती है, वे अपने स्वयं के ईवेंट लूप का निर्माण कर सकते हैं जैसे <code>ConnectionNumber</code>, लेकिन व्यवहार में थ्रेड (कंप्यूटरीकृत) का उपयोग करते हैं। | ||
बहुत कम प्रोग्राम सीधे Xlib का उपयोग करते हैं। अधिक सामान्य स्थिति में, Xlib पर आधारित जीयूआई टूलकिट सामान्यतः ईवेंट जोड़ने का समर्थन करते हैं। उदाहरण के लिए, [[ एक्स टूलकिट इंट्रिनिक्स |एक्स टूलकिट इंट्रिनिक्स]] पर आधारित टूलकिट है <code>XtAppAddInput()</code> और <code>XtAppAddTimeout()</code>. | बहुत कम प्रोग्राम सीधे Xlib का उपयोग करते हैं। अधिक सामान्य स्थिति में, Xlib पर आधारित जीयूआई टूलकिट सामान्यतः ईवेंट जोड़ने का समर्थन करते हैं। उदाहरण के लिए, [[ एक्स टूलकिट इंट्रिनिक्स |एक्स टूलकिट इंट्रिनिक्स]] पर आधारित टूलकिट है <code>XtAppAddInput()</code> और <code>XtAppAddTimeout()</code>. | ||
कृपया ध्यान दें कि सिग्नल हैंडलर से Xlib फ़ंक्शंस को कॉल करना सुरक्षित नहीं है, क्योंकि X एप्लिकेशन मनमाने ढंग से बाधित हो सकता है, | कृपया ध्यान दें कि सिग्नल हैंडलर से Xlib फ़ंक्शंस को कॉल करना सुरक्षित नहीं है, क्योंकि X एप्लिकेशन मनमाने ढंग से बाधित हो सकता है, उदाहरण के लिए अंदर <code>XNextEvent</code>. X11R5, X11R6 और Xt के समाधान के लिए [http://www.ist.co.uk/motif/books/vol6A/ch-26.fm.html] देखें। | ||
=== जीएलआईबी इवेंट लूप === | === जीएलआईबी इवेंट लूप === | ||
[[ GLib | जी लाइब्रेरी]] इवेंट लूप मूल रूप से जीटीके में उपयोग के लिए बनाया गया था, लेकिन अब इसका उपयोग गैर-जीयूआई अनुप्रयोगों में भी किया जाता है, जैसे [[ D-Bus |डी-बस]] । पोल किया गया संसाधन फाइल डिस्क्रिप्टर का संग्रह है जिसमें एप्लिकेशन रुचि रखता है | [[ GLib | जी लाइब्रेरी]] इवेंट लूप मूल रूप से जीटीके में उपयोग के लिए बनाया गया था, लेकिन अब इसका उपयोग गैर-जीयूआई अनुप्रयोगों में भी किया जाता है, जैसे [[ D-Bus |डी-बस]] । पोल किया गया संसाधन फाइल डिस्क्रिप्टर का संग्रह है जिसमें एप्लिकेशन रुचि रखता है, यदि कोई सिग्नल (कंप्यूटरीकृत) आता है या [[ टाइमआउट (कंप्यूटिंग) |टाइमआउट (कंप्यूटरीकृत)]] समाप्त हो जाता है (उदाहरण के लिए यदि एप्लिकेशन ने टाइमआउट या निष्क्रिय कार्य निर्दिष्ट किया है) तो पोलिंग ब्लॉक बाधित हो जाएगा। जबकि जी लाइब्रेरी में फाइल डिस्क्रिप्टर और चाइल्ड टर्मिनेशन इवेंट्स के लिए अंतर्निहित समर्थन है, किसी भी इवेंट के लिए इवेंट स्रोत जोड़ना संभव है जिसे तैयार-जांच-प्रेषण मॉडल में संभाला जा सकता है। [http://developer.gnome.org/ glib/2.30/glib-The-Main-Event-Loop.html#mainloop-states] | ||
जी लाइब्रेरी ईवेंट लूप पर निर्मित एप्लिकेशन लाइब्रेरी में [[ GStreamer |जी स्ट्रीमर]] और [[ GnomeVFS |जीनोम वीएफएस]] की एसिंक्रोनस I/O विधियाँ सम्मलित हैं, लेकिन जीटीके सबसे दृश्यमान क्लाइंट लाइब्रेरी बनी हुई है। [[ विंडोिंग सिस्टम |विंडोिंग सिस्टम]] (एक्स विंडो सिस्टम में, एक्स यूनिक्स डोमेन सॉकेट से पढ़ा गया) की घटनाओं को जीडीके द्वारा [[ जीटीके |जीटीके]] घटनाओं में अनुवादित किया जाता है और एप्लिकेशन के विजेट ऑब्जेक्ट्स पर जीएलआईबी सिग्नल के रूप में उत्सर्जित किया जाता है। | जी लाइब्रेरी ईवेंट लूप पर निर्मित एप्लिकेशन लाइब्रेरी में [[ GStreamer |जी स्ट्रीमर]] और [[ GnomeVFS |जीनोम वीएफएस]] की एसिंक्रोनस I/O विधियाँ सम्मलित हैं, लेकिन जीटीके सबसे दृश्यमान क्लाइंट लाइब्रेरी बनी हुई है। [[ विंडोिंग सिस्टम |विंडोिंग सिस्टम]] (एक्स विंडो सिस्टम में, एक्स यूनिक्स डोमेन सॉकेट से पढ़ा गया) की घटनाओं को जीडीके द्वारा [[ जीटीके |जीटीके]] घटनाओं में अनुवादित किया जाता है और एप्लिकेशन के विजेट ऑब्जेक्ट्स पर जीएलआईबी सिग्नल के रूप में उत्सर्जित किया जाता है। | ||
Line 99: | Line 99: | ||
*[https://msdn.microsoft.com/en-us/library/ms633570.aspx Using Window Procedures (MSDN)] | *[https://msdn.microsoft.com/en-us/library/ms633570.aspx Using Window Procedures (MSDN)] | ||
*[https://msdn.microsoft.com/en-us/library/ms633573.aspx WindowProc (MSDN)] | *[https://msdn.microsoft.com/en-us/library/ms633573.aspx WindowProc (MSDN)] | ||
[[Category: | |||
[[Category:Articles with hatnote templates targeting a nonexistent page]] | |||
[[Category:Created On 02/01/2023]] | [[Category:Created On 02/01/2023]] | ||
[[Category:Machine Translated Page]] | |||
[[Category:Pages with script errors]] | |||
[[Category:Templates Vigyan Ready]] |
Latest revision as of 10:56, 24 January 2023
कंप्यूटर विज्ञान में, इवेंट लूप प्रोग्रामिंग निर्माण या सॉफ्टवेयर डिजाइन पैटर्न है जो कंप्यूटर प्रोग्राम में घटना-संचालित प्रोग्रामिंग या संदेश पासिंग इंटरफ़ेस की प्रतीक्षा करता है और भेजता है। ईवेंट लूप कुछ आंतरिक या बाहरी ईवेंट प्रदाता (जो सामान्यतः किसी ईवेंट के आने तक अनुरोध को अवरुद्ध (कंप्यूटरीकृत) करता है) के लिए अनुरोध करके कार्य करता है, फिर संबंधित आयोजन प्रबंधकर्ता को कॉल करता है (इवेंट को डिस्पैच करता है)। ईवेंट लूप को कभी-कभी संदेश प्रेषक, संदेश लूप, संदेश पंप या रन लूप के रूप में भी जाना जाता है।
ईवेंट-लूप का उपयोग रिएक्टर पैटर्न के संयोजन के साथ किया जा सकता है, यदि ईवेंट प्रदाता फ़ाइल इंटरफ़ेस का अनुसरण करता है, जिसे चुना जा सकता है या 'पोल' किया जा सकता है (यूनिक्स सिस्टम कॉल, वास्तविक मतदान नहीं (कंप्यूटर विज्ञान)) होते हैं। ईवेंट लूप लगभग हमेशा संदेश प्रवर्तक के साथ अतुल्यकालिक रूप से संचालित होता है।
जब इवेंट लूप प्रोग्राम के केंद्रीय नियंत्रण प्रवाह का निर्माण करता है, अधिकांशतः इसे मेन लूप या मेन इवेंट लूप कहा जा सकता है। यह शीर्षक उपयुक्त है, क्योंकि इस प्रकार का इवेंट लूप कार्यक्रम के भीतर उच्चतम स्तर पर नियंत्रण रखता है।
संदेश गुजर रहा है
संदेश पंप को प्रोग्राम की संदेश कतार से संदेशों को 'पंप' करने के लिए कहा जाता है (असाइन किए गए और सामान्यतः अंतर्निहित ऑपरेटिंग सिस्टम के स्वामित्व वाले) प्रसंस्करण के लिए कार्यक्रम में। इसके अन्य अर्थों में, इवेंट लूप अंतर-प्रक्रिया संचार को लागू करने की विधियों में से है। वास्तव में, कई प्रणालियों में संदेश प्रसंस्करण सम्मलित है, जिसमें मच कर्नेल का कर्नेल (कंप्यूटर विज्ञान) या कर्नेल-स्तर घटक सम्मलित है। इवेंट लूप सिस्टम की विशिष्ट कार्यान्वयन तकनीक है जो संदेश देना का उपयोग करती है।
वैकल्पिक डिजाइन
यह दृष्टिकोण कई अन्य विकल्पों के विपरीत है:
- परंपरागत रूप से, कार्यक्रम केवल बार चलता है, फिर समाप्त हो जाता है। कंप्यूटरीकृत को शुरुआती दिनों में इस प्रकार का कार्यक्रम बहुत आम था, और इसमें किसी भी प्रकार की उपयोगकर्ता अन्तरक्रियाशीलता का अभाव था। यह अभी भी अधिकांशतः उपयोग किया जाता है, विशेष रूप से कमांड लाइन या कमांड-लाइन-संचालित प्रोग्राम के रूप में करते हैं। किसी भी मापदंडों को पहले से सेट किया जाता है और प्रोग्राम शुरू होने पर ही इसे पास कर दिया जाता है।
- मेनू चालित डिजाइन में ये अभी भी मुख्य लूप को प्रस्तुत कर सकते हैं, लेकिन सामान्यतः सामान्य अर्थों में इवेंट-संचालित प्रोग्रामिंग के रूप में नहीं सोचा जाता है। इसके अतिरिक्त, उपयोगकर्ता को विकल्पों के कभी-संकीर्ण सेट के साथ प्रस्तुत किया जाता है जब तक कि वे जो कार्य करना चाहते हैं वह एकमात्र विकल्प उपलब्ध नहीं है। मेनू के माध्यम से सीमित अन्तर क्रियाशीलता उपलब्ध है।
उपयोग
ग्राफिकल यूज़र इंटरफ़ेस की प्रबलता के कारण, अधिकांश आधुनिक अनुप्रयोगों में मुख्य लूप होता है। get_next_message()
रूटीन सामान्यतः ऑपरेटिंग सिस्टम द्वारा प्रदान किया जाता है, और संदेश उपलब्ध होने तक ब्लॉक (कंप्यूटरीकृत) किया जाता है। इस प्रकार, लूप केवल तभी दर्ज किया जाता है जब प्रक्रिया करने के लिए कुछ होता है।
function main initialize() while message != quit message := get_next_message() process_message(message) end while
end function
फ़ाइल इंटरफ़ेस
यूनिक्स के अनुसार, सब कुछ फ़ाइल प्रतिमान है जो स्वाभाविक रूप से फ़ाइल-आधारित ईवेंट लूप की ओर ले जाता है। फाइलों से पढ़ना और लिखना, अंतर-प्रक्रिया संचार, नेटवर्क संचार, और डिवाइस नियंत्रण सभी फ़ाइल I/O का उपयोग करके फ़ाइल डिस्क्रिप्टर द्वारा पहचाने गए लक्ष्य के साथ प्राप्त किए जाते हैं। सेलेक्ट (यूनिक्स) और मतदान (यूनिक्स) सिस्टम कॉल फाइल डिस्क्रिप्टर के सेट को स्थिति में बदलाव के लिए मॉनिटर करने की अनुमति देते हैं, उदाहरण के लिए जब डेटा पढ़ने के लिए उपलब्ध हो जाता है।
उदाहरण के लिए, प्रोग्राम पर विचार करें जो निरंतर अद्यतन फ़ाइल से पढ़ता है और एक्स विंडो सिस्टम में इसकी सामग्री प्रदर्शित करता है, जो क्लाइंट के साथ सॉकेट (या तो यूनिक्स डोमेन सॉकेट या बर्कले सॉकेट ) पर संचार करता है
def main():
file_fd = open("logfile.log") x_fd = open_display() construct_interface() while True: rlist, _, _ = select.select([file_fd, x_fd], [], []): if file_fd in rlist: data = file_fd.read() append_to_display(data) send_repaint_message() if x_fd in rlist: process_x_messages()
संकेतों को संभालना
यूनिक्स में कुछ चीजों में से जो फ़ाइल इंटरफ़ेस के अनुरूप नहीं है, अतुल्यकालिक घटनाएँ ( संकेत (कंप्यूटरीकृत) ) हैं। सिग्नल हैंडलर में सिग्नल प्राप्त होते हैं, कोड के छोटे, सीमित टुकड़े जो चलते हैं जबकि शेष कार्य निलंबित रहता है, यदि कार्य अवरुद्ध होने पर संकेत प्राप्त होता है और select()
द्वारा नियंत्रित किया जाता है , लिनक्स में त्रुटि कोड के साथ चयन जल्दी वापस आ जाएगा, यदि कार्य सीपीयू बाउंड होने के समय संकेत प्राप्त होता है, तो सिग्नल हैंडलर के वापस आने तक कार्य को निर्देशों के बीच निलंबित कर दिया जाएगा।
इस प्रकार संकेतों को संभालने का स्पष्ट तरीका सिग्नल संचालकों के लिए वैश्विक ध्वज सेट करना है और ध्वज के लिए इवेंट लूप की जांच तुरंत पहले और बाद में करना है। यदि यह सेट है तो select()
काल करके सिग्नल को उसी प्रकार से संभालें जैसे फ़ाइल डिस्क्रिप्टर पर ईवेंट के साथ करते हैं। दुर्भाग्य से, यह दौड़ की स्थिति को जन्म देता है: यदि फ्लैग की जांच और कॉल करने के बीच तुरंत संकेत आता है select()
, इसे तब तक संभाला नहीं जाएगा select()
किसी अन्य कारण से लौटाता है (उदाहरण के लिए, निराश उपयोगकर्ता द्वारा बाधित किया जाना)।
पासिक्स द्वारा निकाला गया समाधान है pselect()
कॉल, जो समान है select()
लेकिन अतिरिक्त लेता है sigmask
पैरामीटर, जो सिग्नल मास्क का वर्णन करता है। यह एप्लिकेशन को मुख्य कार्य में सिग्नल को मास्क करने की अनुमति देता है, फिर की अवधि के लिए मास्क को हटा दें select()
कॉल ऐसे करें कि सिग्नल हैंडलर को केवल तभी बुलाया जाए जब एप्लिकेशन I/O बाध्य हो। चूंकि, का कार्यान्वयन pselect()
हमेशा विश्वसनीय नहीं रहे हैं, 2.6.16 से पहले के लाइनेक्स के संस्करणों में a नहीं है pselect()
सिस्टम कॉल,[1] glibc को ही दौड़ की स्थिति के लिए प्रवण विधि के माध्यम से इसका अनुकरण करने के लिए मजबूर करना pselect()
बचने का है।
एक वैकल्पिक, अधिक पोर्टेबल समाधान, अतुल्यकालिक घटनाओं को स्व-पाइप चाल का उपयोग करके फ़ाइल-आधारित घटनाओं में परिवर्तित करना है,[2] जहां सिग्नल हैंडलर पाइप को बाइट लिखता है जिसके दूसरे सिरे की जाँच की जाती है select()
मुख्य कार्यक्रम में।[3] लिनक्स कर्नेल संस्करण 2.6.22 में, नया सिस्टम कॉल signalfd()
जोड़ा गया, जो विशेष फाइल डिस्क्रिप्टर के माध्यम से सिग्नल प्राप्त करने की अनुमति देता है।
कार्यान्वयन
विंडोज़ अनुप्रयोग
माइक्रोसाफ्ट विंडोज ऑपरेटिंग सिस्टम पर, प्रक्रिया जो उपयोगकर्ता के साथ इंटरैक्ट करती है उसे आने वाले संदेशों को स्वीकार करना और प्रतिक्रिया देना चाहिए, जो उस प्रक्रिया में माइक्रोसाफ्ट विंडोज में संदेश लूप द्वारा लगभग अनिवार्य रूप से किया जाता है। विंडोज़ में, संदेश ऑपरेटिंग सिस्टम पर निर्मित और लगाए गए ईवेंट के बराबर होता है। घटना अन्य लोगों के बीच उपयोगकर्ता इंटरैक्शन, नेटवर्क ट्रैफ़िक, सिस्टम प्रोसेसिंग, टाइमर गतिविधि, इंटर प्रक्रिया में संचरित हो सकती है। गैर-संवादात्मक, I/O केवल ईवेंट के लिए, विंडोज में इनपुट/आउटपुट समापन पोर्ट|I/O पूर्णता पोर्ट हैं। I/O समापन पोर्ट लूप संदेश लूप से अलग से चलते हैं, और बॉक्स के बाहर संदेश लूप से इंटरैक्ट नहीं करते हैं।
अधिकांश विन32 अनुप्रयोग प्रक्रिया सामग्री का दिल WinMain() फ़ंक्शन है, जो us/library/ms644936.aspx GetMessage() लूप में। GetMessage() संदेश या ईवेंट प्राप्त होने तक ब्लॉक करता है (फ़ंक्शन के साथ PeekMessage() गैर-अवरुद्ध विकल्प के रूप में)। कुछ वैकल्पिक प्रसंस्करण के बाद, यह DispatchMessage() को कॉल करेगा, जो प्रासंगिक हैंडलर को संदेश भेजता है, जिसे विंडोप्रोक भी कहा जाता है। सामान्यतः, जिन संदेशों में कोई विशेष WindowProc() नहीं होता है, उन्हें WindowProc Default_processing, डिफ़ॉल्ट रूप से भेजा जाता है। DispatchMessage() संदेश के एचडब्ल्यूएनडी स्मार्ट सूचक के विंडोप्रोक को कॉल करता है (RegisterClass() फ़ंक्शन के साथ पंजीकृत)।
संदेश आदेश
माइक्रोसाफ्ट विंडोज के अधिक हाल के संस्करण प्रोग्रामर को गारंटी देते हैं कि संदेशों को एप्लिकेशन के संदेश लूप में वितरित किया जाएगा जिससे कि वे सिस्टम और उसके बाह्य उपकरणों द्वारा देखे जा सकें। थ्रेड (कंप्यूटरीकृत) अनुप्रयोगों के डिज़ाइन परिणामों पर विचार करते समय यह गारंटी आवश्यक है। चूंकि, कुछ संदेशों के अलग-अलग नियम होते हैं, जैसे संदेश या भिन्न दस्तावेजी प्राथमिकता वाले संदेश जो हमेशा अंतिम रूप से प्राप्त होते हैं।[4]
एक्स विंडो सिस्टम
एक्सलिब इवेंट लूप
X विंडो सिस्टम एप्लिकेशन सीधे Xlib का उपयोग कर के चारों ओर बनाया गया है XNextEvent
कार्यों का परिवार, XNextEvent
ईवेंट क्यू पर कोई ईवेंट दिखाई देने तक ब्लॉक करता है, जिसके बाद एप्लिकेशन इसे उचित रूप से संसाधित करता है। Xlib इवेंट लूप केवल विंडो सिस्टम इवेंट्स को हैंडल करता है, जिन अनुप्रयोगों को अन्य फ़ाइलों और उपकरणों पर प्रतीक्षा करने में सक्षम होने की आवश्यकता होती है, वे अपने स्वयं के ईवेंट लूप का निर्माण कर सकते हैं जैसे ConnectionNumber
, लेकिन व्यवहार में थ्रेड (कंप्यूटरीकृत) का उपयोग करते हैं।
बहुत कम प्रोग्राम सीधे Xlib का उपयोग करते हैं। अधिक सामान्य स्थिति में, Xlib पर आधारित जीयूआई टूलकिट सामान्यतः ईवेंट जोड़ने का समर्थन करते हैं। उदाहरण के लिए, एक्स टूलकिट इंट्रिनिक्स पर आधारित टूलकिट है XtAppAddInput()
और XtAppAddTimeout()
.
कृपया ध्यान दें कि सिग्नल हैंडलर से Xlib फ़ंक्शंस को कॉल करना सुरक्षित नहीं है, क्योंकि X एप्लिकेशन मनमाने ढंग से बाधित हो सकता है, उदाहरण के लिए अंदर XNextEvent
. X11R5, X11R6 और Xt के समाधान के लिए [1] देखें।
जीएलआईबी इवेंट लूप
जी लाइब्रेरी इवेंट लूप मूल रूप से जीटीके में उपयोग के लिए बनाया गया था, लेकिन अब इसका उपयोग गैर-जीयूआई अनुप्रयोगों में भी किया जाता है, जैसे डी-बस । पोल किया गया संसाधन फाइल डिस्क्रिप्टर का संग्रह है जिसमें एप्लिकेशन रुचि रखता है, यदि कोई सिग्नल (कंप्यूटरीकृत) आता है या टाइमआउट (कंप्यूटरीकृत) समाप्त हो जाता है (उदाहरण के लिए यदि एप्लिकेशन ने टाइमआउट या निष्क्रिय कार्य निर्दिष्ट किया है) तो पोलिंग ब्लॉक बाधित हो जाएगा। जबकि जी लाइब्रेरी में फाइल डिस्क्रिप्टर और चाइल्ड टर्मिनेशन इवेंट्स के लिए अंतर्निहित समर्थन है, किसी भी इवेंट के लिए इवेंट स्रोत जोड़ना संभव है जिसे तैयार-जांच-प्रेषण मॉडल में संभाला जा सकता है। glib/2.30/glib-The-Main-Event-Loop.html#mainloop-states
जी लाइब्रेरी ईवेंट लूप पर निर्मित एप्लिकेशन लाइब्रेरी में जी स्ट्रीमर और जीनोम वीएफएस की एसिंक्रोनस I/O विधियाँ सम्मलित हैं, लेकिन जीटीके सबसे दृश्यमान क्लाइंट लाइब्रेरी बनी हुई है। विंडोिंग सिस्टम (एक्स विंडो सिस्टम में, एक्स यूनिक्स डोमेन सॉकेट से पढ़ा गया) की घटनाओं को जीडीके द्वारा जीटीके घटनाओं में अनुवादित किया जाता है और एप्लिकेशन के विजेट ऑब्जेक्ट्स पर जीएलआईबी सिग्नल के रूप में उत्सर्जित किया जाता है।
macOS कोर फाउंडेशन रन लूप
प्रति थ्रेड ठीक सीएफ रन लूप की अनुमति है, और मनमाने ढंग से कई स्रोत और पर्यवेक्षक संलग्न किए जा सकते हैं। स्रोत तब रन लूप के माध्यम से पर्यवेक्षकों के साथ संवाद करते हैं, इसके साथ श्रेणी बद्ध और संदेशों के प्रेषण का आयोजन करते हैं।
सीएफ रन लूप कोकोआ (एपीआई) में एनएस रन लूप के रूप में अमूर्त है, जो किसी भी संदेश (गैर- प्रतिबिंब (कंप्यूटर विज्ञान) रनटाइम में फ़ंक्शन कॉल के बराबर) को किसी भी वस्तु को प्रेषण के लिए श्रेणी बद्ध करने की अनुमति देता है।
यह भी देखें
- अतुल्यकालिक I/O
- घटना-संचालित प्रोग्रामिंग
- अंतःप्रक्रम संचार
- संदेश देना
- गेम प्रोग्रामिंग में गेम लूप # गेम संरचना
संदर्भ
- ↑ "Linux_2_6_16 - Linux कर्नेल Newbies". kernelnewbies.org. Retrieved 2021-03-03.
- ↑ D. J. Bernstein. "सेल्फ-पाइप ट्रिक".
- ↑ BUGS, Linux Programmer's Manual – System Calls : synchronous I/O multiplexing –
- ↑ GetMessage() function with message priority list.