ग्रैंड सेंट्रल डिस्पैच: Difference between revisions
(Created page with "{{Short description|Technology developed by Apple Inc}} {{Use mdy dates|date=October 2013}} {{primary sources|date=June 2010}} {{infobox software | name = | logo = Image:Gc...") |
No edit summary |
||
Line 1: | Line 1: | ||
{{Short description|Technology developed by Apple Inc}} | {{Short description|Technology developed by Apple Inc}} | ||
{{primary sources|date= | {{primary sources|date=जून 2010}} | ||
{{infobox software | {{infobox software | ||
| name = | | name = | ||
Line 13: | Line 13: | ||
}} | }} | ||
ग्रैंड सेंट्रल डिस्पैच ( | ग्रैंड सेंट्रल डिस्पैच (जीसीडी या libdispatch), [[ मल्टी-कोर (कम्प्यूटिंग) ]] | मल्टी-कोर प्रोसेसर और अन्य [[ सममित बहु प्रसंस्करण ]] सिस्टम वाले सिस्टम के लिए एप्लिकेशन समर्थन को अनुकूलित करने के लिए Apple Inc. द्वारा विकसित एक तकनीक है।<ref>[https://www.apple.com/pr/library/2008/06/09snowleopard.html Apple Previews Mac OS X Snow Leopard to Developers] {{Webarchive|url=https://web.archive.org/web/20120318064324/http://www.apple.com/pr/library/2008/06/09Apple-Previews-Mac-OS-X-Snow-Leopard-to-Developers.html |date=March 18, 2012 }}, June 9, 2008.</ref> यह [[थ्रेड पूल पैटर्न]] के आधार पर [[कार्य समानता]] का कार्यान्वयन है। मौलिक विचार थ्रेड पूल के प्रबंधन को डेवलपर के हाथों से बाहर और ऑपरेटिंग सिस्टम के करीब ले जाना है। डेवलपर पूल के आर्किटेक्चर से बेखबर काम के पैकेज को पूल में इंजेक्ट करता है। यह मॉडल सादगी, पोर्टेबिलिटी और प्रदर्शन में सुधार करता है। | ||
जीसीडी को सबसे पहले Mac OS X 10.6 के साथ रिलीज़ किया गया था, और यह [[iOS (Apple)]] 4 और इसके बाद के संस्करण के साथ भी उपलब्ध है। ग्रैंड सेंट्रल डिस्पैच नाम [[ भव्य केन्द्रीय टर्मिनल ]] का एक संदर्भ है।{{Citation needed|date=June 2010}} | |||
पुस्तकालय के लिए स्रोत कोड जो | पुस्तकालय के लिए स्रोत कोड जो जीसीडी की सेवाओं का कार्यान्वयन प्रदान करता है, libdispatch, Apple द्वारा 10 सितंबर, 2009 को Apache लाइसेंस के तहत जारी किया गया था।<ref>{{Cite web|url=https://apple.github.io/swift-corelibs-libdispatch/|title=ग्रैंड सेंट्रल डिस्पैच|website=apple.github.io}}</ref> इसे पोर्ट किया गया है<ref>{{Cite web |url=http://lists.macosforge.org/pipermail/libdispatch-dev/2009-September/000059.html |title=GCD libdispatch w/Blocks support working on FreeBSD |access-date=September 28, 2009 |archive-date=July 27, 2011 |archive-url=https://web.archive.org/web/20110727053237/http://lists.macosforge.org/pipermail/libdispatch-dev/2009-September/000059.html |url-status=dead }}</ref> फ्रीबीएसडी 8.1+ के लिए,<ref>{{Cite web|url=https://www.freebsd.org/status/report-2009-04-2009-09.html|title=FreeBSD तिमाही स्थिति रिपोर्ट|website=www.freebsd.org}}</ref> [[मिडनाइटबीएसडी]] 0.3+,<ref>{{Cite web|url=https://www.justjournal.com/users/mbsd/entry/18349|title=libdispatch|website=Just Journal}}</ref> लिनक्स, और सोलारिस।<ref>[http://lists.macosforge.org/pipermail/libdispatch-dev/2011-April/000485.html libdispatch mailing list: "Porting status Linux"] April 10, 2011</ref><ref>[http://lists.macosforge.org/pipermail/libdispatch-dev/2011-April/000486.html libdispatch mailing list: "Porting status Solaris x86/64"] April 10, 2011</ref> 2011 में विंडोज़ पर libdispatch काम करने के प्रयासों को अपस्ट्रीम में विलय नहीं किया गया था।<ref>[http://lists.macosforge.org/pipermail/libdispatch-dev/2011-April/000510.html libdispatch mailing list: "libdispatch for Win32"] April 22, 2011</ref><ref>[http://lists.macosforge.org/pipermail/libdispatch-dev/2011-May/000515.html libdispatch mailing list: "Updates regarding the status of libdispatch on Windows"] May 5, 2011</ref> सफारी और आईट्यून्स के साथ भेजे गए विंडोज के लिए Apple के पास libdispatch.dll का अपना पोर्ट है, लेकिन कोई [[ सॉफ़्टवेयर विकास किट ]] प्रदान नहीं किया गया है। | ||
2017 के बाद से, निक हचिंसन द्वारा होस्ट किया गया मूल libdispatch रिपॉजिटरी<ref>{{cite web |last1=Hutchinson |first1=Nicholas |title=libdispatch|url=https://github.com/nickhutchinson/libdispatch|website=GitHub |access-date=15 January 2020 |date=10 January 2020}}</ref> जून 2016 में बनाए गए [[ स्विफ्ट (प्रोग्रामिंग भाषा) ]] कोर लाइब्रेरी का हिस्सा है जो एक संस्करण के पक्ष में पदावनत किया गया था। नया संस्करण अधिक प्लेटफार्मों का समर्थन करता है, विशेष रूप से विंडोज सहित। | 2017 के बाद से, निक हचिंसन द्वारा होस्ट किया गया मूल libdispatch रिपॉजिटरी<ref>{{cite web |last1=Hutchinson |first1=Nicholas |title=libdispatch|url=https://github.com/nickhutchinson/libdispatch|website=GitHub |access-date=15 January 2020 |date=10 January 2020}}</ref> जून 2016 में बनाए गए [[ स्विफ्ट (प्रोग्रामिंग भाषा) ]] कोर लाइब्रेरी का हिस्सा है जो एक संस्करण के पक्ष में पदावनत किया गया था। नया संस्करण अधिक प्लेटफार्मों का समर्थन करता है, विशेष रूप से विंडोज सहित। | ||
Line 25: | Line 25: | ||
जीसीडी एक प्रोग्राम में विशिष्ट [[कार्य (कंप्यूटिंग)]] की अनुमति देकर काम करता है जिसे निष्पादन के लिए कतारबद्ध करने के लिए समानांतर में चलाया जा सकता है और प्रसंस्करण संसाधनों की उपलब्धता के आधार पर, उन्हें किसी भी उपलब्ध प्रोसेसर कोर पर निष्पादित करने के लिए [[शेड्यूलिंग (कंप्यूटिंग)]] किया जाता है।<ref name="gcdworks">{{cite web|url=https://images.apple.com/macosx/technology/docs/GrandCentral_TB_brief_20090903.pdf |title=ग्रैंड सेंट्रल डिस्पैच पर एप्पल टेक्निकल ब्रीफ|access-date=2009-09-12 |url-status=bot: unknown |archive-url=https://web.archive.org/web/20090920043909/http://images.apple.com/macosx/technology/docs/GrandCentral_TB_brief_20090903.pdf |archive-date=September 20, 2009 |df=mdy-all }}</ref><ref name=OSConcepts>{{cite book|last=Gagne|first=Abraham Silberschatz, Peter Baer Galvin, Greg|title=ऑपरेटिंग सिस्टम की अवधारणाएँ|year=2013|publisher=Wiley|location=Hoboken, N.J.|isbn=9781118063330|pages=182–183|edition=9th}}</ref> (Apple द्वारा रूटिंग के रूप में संदर्भित)।<ref>{{cite web|url=http://www.roughlydrafted.com/2008/06/12/wwdc-2008-new-in-mac-os-x-snow-leopard/|title=WWDC 2008: New in Mac OS X Snow Leopard|access-date=June 18, 2008|archive-url=https://web.archive.org/web/20081017052319/http://www.roughlydrafted.com/2008/06/12/wwdc-2008-new-in-mac-os-x-snow-leopard/|archive-date=October 17, 2008|url-status=dead}}</ref> | जीसीडी एक प्रोग्राम में विशिष्ट [[कार्य (कंप्यूटिंग)]] की अनुमति देकर काम करता है जिसे निष्पादन के लिए कतारबद्ध करने के लिए समानांतर में चलाया जा सकता है और प्रसंस्करण संसाधनों की उपलब्धता के आधार पर, उन्हें किसी भी उपलब्ध प्रोसेसर कोर पर निष्पादित करने के लिए [[शेड्यूलिंग (कंप्यूटिंग)]] किया जाता है।<ref name="gcdworks">{{cite web|url=https://images.apple.com/macosx/technology/docs/GrandCentral_TB_brief_20090903.pdf |title=ग्रैंड सेंट्रल डिस्पैच पर एप्पल टेक्निकल ब्रीफ|access-date=2009-09-12 |url-status=bot: unknown |archive-url=https://web.archive.org/web/20090920043909/http://images.apple.com/macosx/technology/docs/GrandCentral_TB_brief_20090903.pdf |archive-date=September 20, 2009 |df=mdy-all }}</ref><ref name=OSConcepts>{{cite book|last=Gagne|first=Abraham Silberschatz, Peter Baer Galvin, Greg|title=ऑपरेटिंग सिस्टम की अवधारणाएँ|year=2013|publisher=Wiley|location=Hoboken, N.J.|isbn=9781118063330|pages=182–183|edition=9th}}</ref> (Apple द्वारा रूटिंग के रूप में संदर्भित)।<ref>{{cite web|url=http://www.roughlydrafted.com/2008/06/12/wwdc-2008-new-in-mac-os-x-snow-leopard/|title=WWDC 2008: New in Mac OS X Snow Leopard|access-date=June 18, 2008|archive-url=https://web.archive.org/web/20081017052319/http://www.roughlydrafted.com/2008/06/12/wwdc-2008-new-in-mac-os-x-snow-leopard/|archive-date=October 17, 2008|url-status=dead}}</ref> | ||
एक कार्य या तो एक उपनेमका के रूप में या एक ब्लॉक (सी भाषा विस्तार) के रूप में व्यक्त किया जा सकता है।<ref>{{cite web|title=ग्रैंड सेंट्रल डिस्पैच (जीसीडी) संदर्भ|url=https://developer.apple.com/library/mac/documentation/Performance/Reference/GCD_libdispatch_Ref/|access-date=September 13, 2009}}</ref> ब्लॉक [[ सी (प्रोग्रामिंग भाषा) ]], [[सी ++]], और [[ उद्देश्य सी ]] प्रोग्रामिंग लैंग्वेज के सिंटैक्स का एक विस्तार है जो एक [[क्लोजर (कंप्यूटर साइंस)]] के समान एक ऑब्जेक्ट में कोड और डेटा को एनकैप्सुलेट करता है।<ref name="gcdworks"/>जीसीडी अभी भी उन वातावरणों में उपयोग किया जा सकता है जहां ब्लॉक उपलब्ध नहीं हैं।<ref>{{Cite web|url=https://wiki.freebsd.org/GCD#The_same_program.2C_without_C_Blocks|title = GrandCentralDispatch - FreeBSD Wiki}}</ref> | एक कार्य या तो एक उपनेमका के रूप में या एक ब्लॉक (सी भाषा विस्तार) के रूप में व्यक्त किया जा सकता है।<ref>{{cite web|title=ग्रैंड सेंट्रल डिस्पैच (जीसीडी) संदर्भ|url=https://developer.apple.com/library/mac/documentation/Performance/Reference/GCD_libdispatch_Ref/|access-date=September 13, 2009}}</ref> ब्लॉक [[ सी (प्रोग्रामिंग भाषा) ]], [[सी ++]], और [[ उद्देश्य सी ]] प्रोग्रामिंग लैंग्वेज के सिंटैक्स का एक विस्तार है जो एक [[क्लोजर (कंप्यूटर साइंस)]] के समान एक ऑब्जेक्ट में कोड और डेटा को एनकैप्सुलेट करता है।<ref name="gcdworks"/>जीसीडी अभी भी उन वातावरणों में उपयोग किया जा सकता है जहां ब्लॉक उपलब्ध नहीं हैं।<ref>{{Cite web|url=https://wiki.freebsd.org/GCD#The_same_program.2C_without_C_Blocks|title = GrandCentralDispatch - FreeBSD Wiki}}</ref> | ||
ग्रैंड सेंट्रल डिस्पैच अभी भी निम्न स्तर पर थ्रेड्स का उपयोग करता है लेकिन उन्हें प्रोग्रामर से दूर कर देता है, जिन्हें अधिक विवरणों से चिंतित होने की आवश्यकता नहीं होगी। | ग्रैंड सेंट्रल डिस्पैच अभी भी निम्न स्तर पर थ्रेड्स का उपयोग करता है लेकिन उन्हें प्रोग्रामर से दूर कर देता है, जिन्हें अधिक विवरणों से चिंतित होने की आवश्यकता नहीं होगी। जीसीडी में कार्य बनाने और क्यू करने में हल्के होते हैं; Apple का कहना है कि जीसीडी में एक कार्य इकाई को पंक्तिबद्ध करने के लिए 15 निर्देशों की आवश्यकता होती है, जबकि पारंपरिक थ्रेड बनाने के लिए आसानी से कई सौ निर्देशों की आवश्यकता हो सकती है।<ref name="gcdworks"/> | ||
ग्रैंड सेंट्रल डिस्पैच में एक कार्य का उपयोग या तो कतार में रखा गया कार्य आइटम बनाने के लिए किया जा सकता है या इसे किसी ईवेंट स्रोत को असाइन किया जा सकता है। यदि किसी ईवेंट स्रोत को कोई कार्य सौंपा गया है, तो ईवेंट ट्रिगर होने पर ब्लॉक या फ़ंक्शन से कार्य इकाई बनाई जाती है, और कार्य इकाई को उचित कतार में रखा जाता है। यह Apple द्वारा एक थ्रेड बनाने की तुलना में अधिक कुशल के रूप में वर्णित किया गया है जिसका एकमात्र उद्देश्य ट्रिगरिंग के एकल ईवेंट पर प्रतीक्षा करना है। | ग्रैंड सेंट्रल डिस्पैच में एक कार्य का उपयोग या तो कतार में रखा गया कार्य आइटम बनाने के लिए किया जा सकता है या इसे किसी ईवेंट स्रोत को असाइन किया जा सकता है। यदि किसी ईवेंट स्रोत को कोई कार्य सौंपा गया है, तो ईवेंट ट्रिगर होने पर ब्लॉक या फ़ंक्शन से कार्य इकाई बनाई जाती है, और कार्य इकाई को उचित कतार में रखा जाता है। यह Apple द्वारा एक थ्रेड बनाने की तुलना में अधिक कुशल के रूप में वर्णित किया गया है जिसका एकमात्र उद्देश्य ट्रिगरिंग के एकल ईवेंट पर प्रतीक्षा करना है। | ||
Line 110: | Line 110: | ||
== अनुप्रयोग == | == अनुप्रयोग == | ||
जीसीडी का उपयोग पूरे macOS (10.6 स्नो लेपर्ड से शुरू) में किया जाता है, और Apple ने macOS एप्लिकेशन डेवलपर्स द्वारा इसे अपनाने के लिए प्रोत्साहित किया है। FreeBSD डेवलपर [[रॉबर्ट वाटसन (कंप्यूटर वैज्ञानिक)]] ने 11 मई, 2010 को Apache जीसीडी MPM (मल्टी-प्रोसेसिंग मॉड्यूल) के माध्यम से जीसीडी का उपयोग करने के लिए एक प्रमुख ओपन सोर्स एप्लिकेशन, Apache HTTP सर्वर के पहले अनुकूलन की घोषणा की, ताकि प्रोग्रामिंग को स्पष्ट किया जा सके। मॉडल और जीसीडी को मौजूदा, बड़े पैमाने पर बहु-थ्रेडेड, अनुप्रयोगों में कैसे एकीकृत किया जाए। उनकी घोषणा ने देखा कि जीसीडी एमपीएम में अन्य थ्रेडेड एमपीएम के रूप में लाइनों की संख्या एक तिहाई से आधी थी।<ref name="libdispatch-apache-announcement">[http://lists.macosforge.org/pipermail/libdispatch-dev/2010-May/000352.html libdispatch-dev GCD MPM for Apache] (accessed May 14, 2010)</ref><ref name="apache-gcd-mpm">[http://libdispatch.macosforge.org/trac/wiki/apache apache-libdispatch] (accessed May 14, 2010)</ref> | |||
== आंतरिक == | == आंतरिक == | ||
जीसीडी को libdispatch द्वारा कार्यान्वित किया गया है, Apple द्वारा विकसित pthreads गैर-POSIX एक्सटेंशन के समर्थन से। जीसीडी (10.6), माउंटेन लायन (10.8) और मावेरिक्स (10.9) के आधिकारिक लॉन्च के माध्यम से Apple ने अपनी स्थापना के बाद से (OS X 10.5 में) इंटरफ़ेस बदल दिया है। नवीनतम परिवर्तनों में उपयोगकर्ता मोड और कर्नेल दोनों में pthreads का समर्थन करने वाले कोड बनाना शामिल है, निजी (कर्नेल pthread समर्थन के साथ केवल शिम्स तक कम हो गया है, और वास्तविक कार्य कतार कार्यान्वयन एक अलग कर्नेल एक्सटेंशन में चला गया है)।<ref name="GCD Internals">{{cite web |url=http://newosxbook.com/articles/GCD.html |title=GCD Internals: The undocumented side of the Grand Central Dispatcher |last1=Levin |first1=Jonathan |date=15 February 2014 |access-date=17 March 2014}}</ref> | |||
अन्य प्रणालियों पर, libdispatch सिस्टम की स्वयं की ईवेंट सुविधाओं (epoll, kevent, या Windows NT) का उपयोग करके अपने स्वयं के वर्कक्यू को लागू करता है। MacOS पर, kevent का उपयोग कर्नेल वर्कक्यू के साथ किया जाता है। | अन्य प्रणालियों पर, libdispatch सिस्टम की स्वयं की ईवेंट सुविधाओं (epoll, kevent, या Windows NT) का उपयोग करके अपने स्वयं के वर्कक्यू को लागू करता है। MacOS पर, kevent का उपयोग कर्नेल वर्कक्यू के साथ किया जाता है। | ||
Line 130: | Line 130: | ||
== बाहरी संबंध == | == बाहरी संबंध == | ||
* [https://apple.github.io/swift-corelibs-libdispatch/ | * [https://apple.github.io/swift-corelibs-libdispatch/ जीसीडी project on GitHub] | ||
* [https://developer.apple.com/documentation/dispatch | * [https://developer.apple.com/documentation/dispatch जीसीडी Reference from the Mac Developer Library] | ||
* [https://web.archive.org/web/20130504142911/http://developer.apple.com/library/mac/#featuredarticles/BlocksGCD/_index.html The ''Introducing Blocks and Grand Central Dispatch'' article from the Mac Developer Library] | * [https://web.archive.org/web/20130504142911/http://developer.apple.com/library/mac/#featuredarticles/BlocksGCD/_index.html The ''Introducing Blocks and Grand Central Dispatch'' article from the Mac Developer Library] | ||
Revision as of 21:08, 10 March 2023
This article relies excessively on references to primary sources. (जून 2010) (Learn how and when to remove this template message) |
GCD | |
Original author(s) | Dave Zarzycki |
---|---|
Developer(s) | Apple Inc. |
Operating system | Mac OS X 10.6 (2009) and later, iOS 4.0 and later,[1] watchOS, tvOS, FreeBSD |
Type | System Utility |
License | Apache 2.0 |
Website | https://apple.github.io/swift-corelibs-libdispatch/ |
ग्रैंड सेंट्रल डिस्पैच (जीसीडी या libdispatch), मल्टी-कोर (कम्प्यूटिंग) | मल्टी-कोर प्रोसेसर और अन्य सममित बहु प्रसंस्करण सिस्टम वाले सिस्टम के लिए एप्लिकेशन समर्थन को अनुकूलित करने के लिए Apple Inc. द्वारा विकसित एक तकनीक है।[2] यह थ्रेड पूल पैटर्न के आधार पर कार्य समानता का कार्यान्वयन है। मौलिक विचार थ्रेड पूल के प्रबंधन को डेवलपर के हाथों से बाहर और ऑपरेटिंग सिस्टम के करीब ले जाना है। डेवलपर पूल के आर्किटेक्चर से बेखबर काम के पैकेज को पूल में इंजेक्ट करता है। यह मॉडल सादगी, पोर्टेबिलिटी और प्रदर्शन में सुधार करता है।
जीसीडी को सबसे पहले Mac OS X 10.6 के साथ रिलीज़ किया गया था, और यह iOS (Apple) 4 और इसके बाद के संस्करण के साथ भी उपलब्ध है। ग्रैंड सेंट्रल डिस्पैच नाम भव्य केन्द्रीय टर्मिनल का एक संदर्भ है।[citation needed]
पुस्तकालय के लिए स्रोत कोड जो जीसीडी की सेवाओं का कार्यान्वयन प्रदान करता है, libdispatch, Apple द्वारा 10 सितंबर, 2009 को Apache लाइसेंस के तहत जारी किया गया था।[3] इसे पोर्ट किया गया है[4] फ्रीबीएसडी 8.1+ के लिए,[5] मिडनाइटबीएसडी 0.3+,[6] लिनक्स, और सोलारिस।[7][8] 2011 में विंडोज़ पर libdispatch काम करने के प्रयासों को अपस्ट्रीम में विलय नहीं किया गया था।[9][10] सफारी और आईट्यून्स के साथ भेजे गए विंडोज के लिए Apple के पास libdispatch.dll का अपना पोर्ट है, लेकिन कोई सॉफ़्टवेयर विकास किट प्रदान नहीं किया गया है।
2017 के बाद से, निक हचिंसन द्वारा होस्ट किया गया मूल libdispatch रिपॉजिटरी[11] जून 2016 में बनाए गए स्विफ्ट (प्रोग्रामिंग भाषा) कोर लाइब्रेरी का हिस्सा है जो एक संस्करण के पक्ष में पदावनत किया गया था। नया संस्करण अधिक प्लेटफार्मों का समर्थन करता है, विशेष रूप से विंडोज सहित।
डिजाइन
जीसीडी एक प्रोग्राम में विशिष्ट कार्य (कंप्यूटिंग) की अनुमति देकर काम करता है जिसे निष्पादन के लिए कतारबद्ध करने के लिए समानांतर में चलाया जा सकता है और प्रसंस्करण संसाधनों की उपलब्धता के आधार पर, उन्हें किसी भी उपलब्ध प्रोसेसर कोर पर निष्पादित करने के लिए शेड्यूलिंग (कंप्यूटिंग) किया जाता है।[12][13] (Apple द्वारा रूटिंग के रूप में संदर्भित)।[14] एक कार्य या तो एक उपनेमका के रूप में या एक ब्लॉक (सी भाषा विस्तार) के रूप में व्यक्त किया जा सकता है।[15] ब्लॉक सी (प्रोग्रामिंग भाषा) , सी ++, और उद्देश्य सी प्रोग्रामिंग लैंग्वेज के सिंटैक्स का एक विस्तार है जो एक क्लोजर (कंप्यूटर साइंस) के समान एक ऑब्जेक्ट में कोड और डेटा को एनकैप्सुलेट करता है।[12]जीसीडी अभी भी उन वातावरणों में उपयोग किया जा सकता है जहां ब्लॉक उपलब्ध नहीं हैं।[16] ग्रैंड सेंट्रल डिस्पैच अभी भी निम्न स्तर पर थ्रेड्स का उपयोग करता है लेकिन उन्हें प्रोग्रामर से दूर कर देता है, जिन्हें अधिक विवरणों से चिंतित होने की आवश्यकता नहीं होगी। जीसीडी में कार्य बनाने और क्यू करने में हल्के होते हैं; Apple का कहना है कि जीसीडी में एक कार्य इकाई को पंक्तिबद्ध करने के लिए 15 निर्देशों की आवश्यकता होती है, जबकि पारंपरिक थ्रेड बनाने के लिए आसानी से कई सौ निर्देशों की आवश्यकता हो सकती है।[12]
ग्रैंड सेंट्रल डिस्पैच में एक कार्य का उपयोग या तो कतार में रखा गया कार्य आइटम बनाने के लिए किया जा सकता है या इसे किसी ईवेंट स्रोत को असाइन किया जा सकता है। यदि किसी ईवेंट स्रोत को कोई कार्य सौंपा गया है, तो ईवेंट ट्रिगर होने पर ब्लॉक या फ़ंक्शन से कार्य इकाई बनाई जाती है, और कार्य इकाई को उचित कतार में रखा जाता है। यह Apple द्वारा एक थ्रेड बनाने की तुलना में अधिक कुशल के रूप में वर्णित किया गया है जिसका एकमात्र उद्देश्य ट्रिगरिंग के एकल ईवेंट पर प्रतीक्षा करना है।
विशेषताएं
डिस्पैच फ्रेमवर्क उन्हें बनाने और हेरफेर करने के लिए कई डेटा प्रकारों और कार्यों की घोषणा करता है:
- प्रेषण कतारें ऐसी वस्तुएं हैं जो कार्यों की एक कतार बनाए रखती हैं, या तो अनाम कोड ब्लॉक या फ़ंक्शन, और इन कार्यों को अपनी बारी में निष्पादित करती हैं। पुस्तकालय स्वचालित रूप से विभिन्न प्राथमिकता स्तरों के साथ कई कतारें बनाता है जो ऑपरेटिंग वातावरण के आधार पर चलने के लिए इष्टतम संख्या का चयन करते हुए कई कार्यों को समवर्ती रूप से निष्पादित करते हैं। लाइब्रेरी के लिए एक ग्राहक किसी भी संख्या में सीरियल क्यू भी बना सकता है, जो एक बार में सबमिट किए गए क्रम में कार्यों को निष्पादित करता है।[13]चूंकि एक सीरियल कतार एक समय में केवल एक कार्य चला सकती है, कतार में सबमिट किया गया प्रत्येक कार्य कतार पर अन्य कार्यों के संबंध में महत्वपूर्ण है, और इस प्रकार एक तर्कबद्ध पर लॉक (कंप्यूटर विज्ञान) के बजाय एक सीरियल कतार का उपयोग किया जा सकता है। संसाधन।
- डिस्पैच स्रोत ऐसी वस्तुएं हैं जो क्लाइंट को ब्लॉक या फ़ंक्शंस को सिस्टम ईवेंट पर अतुल्यकालिक रूप से निष्पादित करने के लिए पंजीकृत करने की अनुमति देती हैं, जैसे कि यूनिक्स डोमेन सॉकेट या फाइल डिस्क्रिप्टर पढ़ने या लिखने के लिए तैयार है, या एक POSIX सिग्नल (कंप्यूटिंग)।
- डिस्पैच ग्रुप ऐसे ऑब्जेक्ट हैं जो कई कार्यों को बाद में शामिल होने के लिए समूहीकृत करने की अनुमति देते हैं। समूह के सदस्य के रूप में कार्य कतार में जोड़े जा सकते हैं, और तब ग्राहक समूह ऑब्जेक्ट का उपयोग उस समूह के सभी कार्यों के पूरा होने तक प्रतीक्षा करने के लिए कर सकता है।
- डिस्पैच सेमाफोर ऐसी वस्तुएं हैं जो क्लाइंट को एक साथ निष्पादित करने के लिए केवल कुछ निश्चित कार्यों की अनुमति देती हैं।
Libdispatch अपने स्वयं के ऑब्जेक्ट मॉडल, OS ऑब्जेक्ट के साथ आता है, जो आंशिक रूप से Objective-C मॉडल के साथ संगत है। नतीजतन, इसकी वस्तुओं को ओबीजेसी वस्तुओं के लिए टोल-फ्री ब्रिज किया जा सकता है।[17]
उदाहरण
This article is written like a manual or guidebook. (June 2010) (Learn how and when to remove this template message) |
ग्रैंड सेंट्रल डिस्पैच के उपयोग को प्रदर्शित करने वाले दो उदाहरण जॉन सिराकुसा की आर्स टेक्निका स्नो लेपर्ड समीक्षा में देखे जा सकते हैं।[18] प्रारंभ में, एक दस्तावेज़-आधारित एप्लिकेशन में एक विधि होती है, जिसे कहा जाता है analyzeDocument
जो दस्तावेज़ में शब्दों और अनुच्छेदों की संख्या गिनने जैसा कुछ कर सकता है। आम तौर पर, यह एक त्वरित प्रक्रिया होगी, और उपयोगकर्ता को बटन दबाने और परिणाम दिखाने के बीच देरी के बिना मुख्य धागे में निष्पादित किया जा सकता है।
- (IBAction)analyzeDocument:(NSButton *)sender {
NSDictionary *stats = [myDoc analyze];
[myModel setDict:stats];
[myStatsView setNeedsDisplay:YES];
}
यदि दस्तावेज़ बड़ा है और विश्लेषण को निष्पादित करने में लंबा समय लगता है तो मुख्य थ्रेड फ़ंक्शन के समाप्त होने की प्रतीक्षा करेगा। यदि इसमें पर्याप्त समय लगता है, तो उपयोगकर्ता नोटिस करेगा, और एप्लिकेशन घूमता हुआ पहिया भी कर सकता है। समाधान यहाँ देखा जा सकता है:
- (IBAction)analyzeDocument:(NSButton *)sender {
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
NSDictionary *stats = [myDoc analyze];
dispatch_async(dispatch_get_main_queue(), ^{
[myModel setDict:stats];
[myStatsView setNeedsDisplay:YES];
});
});
}
यहाँ, कॉल करने के लिए [myDoc analyze]
एक अज्ञात फ़ंक्शन के अंदर रखा जाता है, जिसे बाद में वैश्विक समवर्ती कतारों में से एक पर रखा जाता है। इसके चलने के बाद [myDoc analyze]
, मुख्य कतार (जिस पर एप्लिकेशन का मुख्य थ्रेड चलता है) पर एक नया ब्लॉक रखा गया है, जो GUI को अपडेट करता है (यह आवश्यक है क्योंकि GUI को केवल मुख्य थ्रेड द्वारा अपडेट किया जा सकता है)। इन दो छोटे बदलावों को करके, डेवलपर ने उपयोगकर्ता द्वारा देखे गए एप्लिकेशन के संभावित स्टाल से बचा लिया है, और अपने एप्लिकेशन को हार्डवेयर संसाधनों का बेहतर उपयोग करने की अनुमति दी है।
दूसरा उदाहरण for लूप को समानांतर करने का है:
for (i = 0; i < count; i++) {
results[i] = do_work(data, i);
}
total = summarize(results, count);
यह कोड चलाता है do_work
समारोह count
बार, i असाइन करनाth आई के परिणामth सरणी में तत्व results
, और उसके बाद लूप समाप्त होने के बाद सरणी पर सारांशित करें। दुर्भाग्य से काम की गणना क्रमिक रूप से की जाती है, जहाँ इसकी आवश्यकता नहीं हो सकती है। यह मानते हुए कि do_work इसे किए गए किसी भी अन्य कॉल के परिणामों पर भरोसा नहीं करता है, ऐसा कोई कारण नहीं है कि इन कॉलों को एक साथ नहीं किया जा सकता है। जीसीडी में यह कैसे किया जाएगा:
dispatch_apply(count, dispatch_get_global_queue(0, 0), ^(size_t i){
results[i] = do_work(data, i);
});
total = summarize(results, count);
यहाँ, dispatch_apply
इसे दिए गए ब्लॉक को चलाता है, count
समय, प्रत्येक मंगलाचरण को एक वैश्विक कतार में रखना, और प्रत्येक आह्वान को 0 से एक अलग संख्या में पारित करना count
-1। यह ओएस को काम को फैलाने की इजाजत देगा क्योंकि यह फिट दिखता है, मौजूदा हार्डवेयर और सिस्टम लोड के लिए चलने वाले धागे की इष्टतम संख्या चुनता है। dispatch_apply
यह तब तक वापस नहीं आता जब तक कि दी गई कतार में रखे गए सभी ब्लॉकों का निष्पादन पूरा नहीं हो जाता, ताकि यह गारंटी दी जा सके कि कॉल करने से पहले मूल लूप के अंदर सभी काम पूरे हो गए हैं summarize
.
प्रोग्रामर उन कार्यों के लिए अपनी खुद की सीरियल कतारें बना सकते हैं जिन्हें वे जानते हैं कि उन्हें क्रमिक रूप से चलना चाहिए लेकिन जिन्हें एक अलग थ्रेड पर निष्पादित किया जा सकता है। एक नई कतार इस प्रकार बनाई जाएगी:
dispatch_queue_t exampleQueue;
exampleQueue = dispatch_queue_create( "com.example.unique.identifier", NULL );
// exampleQueue may be used here.
dispatch_release( exampleQueue );
कतार पर एक डिस्पैच किए गए ब्लॉक से बचने के लिए सावधानी बरती जानी चाहिए क्योंकि यह गतिरोध की गारंटी है। ऐसा कोड निम्न कार्य कर सकता है:
dispatch_queue_t exampleQueue = dispatch_queue_create( "com.example.unique.identifier", NULL );
dispatch_sync( exampleQueue, ^{
dispatch_sync( exampleQueue, ^{
printf( "I am now deadlocked...\n" );
});
});
dispatch_release( exampleQueue );
अनुप्रयोग
जीसीडी का उपयोग पूरे macOS (10.6 स्नो लेपर्ड से शुरू) में किया जाता है, और Apple ने macOS एप्लिकेशन डेवलपर्स द्वारा इसे अपनाने के लिए प्रोत्साहित किया है। FreeBSD डेवलपर रॉबर्ट वाटसन (कंप्यूटर वैज्ञानिक) ने 11 मई, 2010 को Apache जीसीडी MPM (मल्टी-प्रोसेसिंग मॉड्यूल) के माध्यम से जीसीडी का उपयोग करने के लिए एक प्रमुख ओपन सोर्स एप्लिकेशन, Apache HTTP सर्वर के पहले अनुकूलन की घोषणा की, ताकि प्रोग्रामिंग को स्पष्ट किया जा सके। मॉडल और जीसीडी को मौजूदा, बड़े पैमाने पर बहु-थ्रेडेड, अनुप्रयोगों में कैसे एकीकृत किया जाए। उनकी घोषणा ने देखा कि जीसीडी एमपीएम में अन्य थ्रेडेड एमपीएम के रूप में लाइनों की संख्या एक तिहाई से आधी थी।[19][20]
आंतरिक
जीसीडी को libdispatch द्वारा कार्यान्वित किया गया है, Apple द्वारा विकसित pthreads गैर-POSIX एक्सटेंशन के समर्थन से। जीसीडी (10.6), माउंटेन लायन (10.8) और मावेरिक्स (10.9) के आधिकारिक लॉन्च के माध्यम से Apple ने अपनी स्थापना के बाद से (OS X 10.5 में) इंटरफ़ेस बदल दिया है। नवीनतम परिवर्तनों में उपयोगकर्ता मोड और कर्नेल दोनों में pthreads का समर्थन करने वाले कोड बनाना शामिल है, निजी (कर्नेल pthread समर्थन के साथ केवल शिम्स तक कम हो गया है, और वास्तविक कार्य कतार कार्यान्वयन एक अलग कर्नेल एक्सटेंशन में चला गया है)।[21] अन्य प्रणालियों पर, libdispatch सिस्टम की स्वयं की ईवेंट सुविधाओं (epoll, kevent, या Windows NT) का उपयोग करके अपने स्वयं के वर्कक्यू को लागू करता है। MacOS पर, kevent का उपयोग कर्नेल वर्कक्यू के साथ किया जाता है।
यह भी देखें
- कार्य समानांतर पुस्तकालय
- जावा समवर्ती
- ओपनएमपी
- थ्रेडिंग बिल्डिंग ब्लॉक्स (टीबीबी)
संदर्भ
- ↑ "Grand Central Dispatch (GCD) Reference". Apple Inc.
- ↑ Apple Previews Mac OS X Snow Leopard to Developers Archived March 18, 2012, at the Wayback Machine, June 9, 2008.
- ↑ "ग्रैंड सेंट्रल डिस्पैच". apple.github.io.
- ↑ "GCD libdispatch w/Blocks support working on FreeBSD". Archived from the original on July 27, 2011. Retrieved September 28, 2009.
- ↑ "FreeBSD तिमाही स्थिति रिपोर्ट". www.freebsd.org.
- ↑ "libdispatch". Just Journal.
- ↑ libdispatch mailing list: "Porting status Linux" April 10, 2011
- ↑ libdispatch mailing list: "Porting status Solaris x86/64" April 10, 2011
- ↑ libdispatch mailing list: "libdispatch for Win32" April 22, 2011
- ↑ libdispatch mailing list: "Updates regarding the status of libdispatch on Windows" May 5, 2011
- ↑ Hutchinson, Nicholas (10 January 2020). "libdispatch". GitHub. Retrieved 15 January 2020.
- ↑ 12.0 12.1 12.2 "ग्रैंड सेंट्रल डिस्पैच पर एप्पल टेक्निकल ब्रीफ" (PDF). Archived from the original on September 20, 2009. Retrieved September 12, 2009.
{{cite web}}
: CS1 maint: bot: original URL status unknown (link) - ↑ 13.0 13.1 Gagne, Abraham Silberschatz, Peter Baer Galvin, Greg (2013). ऑपरेटिंग सिस्टम की अवधारणाएँ (9th ed.). Hoboken, N.J.: Wiley. pp. 182–183. ISBN 9781118063330.
{{cite book}}
: CS1 maint: multiple names: authors list (link) - ↑ "WWDC 2008: New in Mac OS X Snow Leopard". Archived from the original on October 17, 2008. Retrieved June 18, 2008.
- ↑ "ग्रैंड सेंट्रल डिस्पैच (जीसीडी) संदर्भ". Retrieved September 13, 2009.
- ↑ "GrandCentralDispatch - FreeBSD Wiki".
- ↑ Bugaev, Sergey. "मच-ओ लिंकिंग और लोडिंग ट्रिक्स". Darling development blog. Retrieved 15 January 2020.
- ↑ Mac OS X 10.6 Snow Leopard: the Ars Technica review (accessed September 2, 2009)
- ↑ libdispatch-dev GCD MPM for Apache (accessed May 14, 2010)
- ↑ apache-libdispatch (accessed May 14, 2010)
- ↑ Levin, Jonathan (15 February 2014). "GCD Internals: The undocumented side of the Grand Central Dispatcher". Retrieved 17 March 2014.