टास्क (कंप्यूटिंग)

From Vigyanwiki
Revision as of 15:06, 15 March 2023 by alpha>Neeraja (added Category:Vigyan Ready using HotCat)
कार्य की इकाई के रूप में कार्य के अर्थ में प्रतीक्षा कार्यों (नीला) और पूर्ण कार्यों (पीला) की कार्य कतार के साथ एक नमूना थ्रेड पूल (हरा बॉक्स)।

कंप्यूटर में, कार्य निष्पादन (कंप्यूटिंग) की इकाई या कार्य एक इकाई है। यह शब्द अस्पष्ट है; स्पष्ट वैकल्पिक शब्दों में प्रक्रिया (कंप्यूटिंग), सरलतम प्रक्रिया, थ्रेड (कंप्यूटिंग) (निष्पादन के लिए), स्टेप, अनुरोध-प्रतिक्रिया, या क्वेरी' सम्मिलित हैं। ' (काम के लिए)। आसन्न आरेख में, आने वाले कार्य और आउटगोइंग पूर्ण कार्य की कतार है, और इस कार्य को करने के लिए थ्रेड्स का थ्रेड पूल है। या तो स्वयं कार्य इकाइयाँ या कार्य करने वाले थ्रेड्स को कार्यों के रूप में संदर्भित किया जा सकता है, और इन्हें क्रमशः अनुरोध / प्रतिक्रिया / थ्रेड, आने वाले कार्य / पूर्ण कार्य / थ्रेड (जैसा कि सचित्र), या अनुरोध / प्रतिक्रिया / के रूप में संदर्भित किया जा सकता है।

शब्दावली

निष्पादन की इकाई के अर्थ में, कुछ ऑपरेटिंग सिस्टम में कार्य एक प्रक्रिया (कंप्यूटिंग) का पर्याय है, और अन्य में थ्रेड के साथ (कंप्यूटिंग). गैर-संवादात्मक निष्पादन (प्रचय संसाधन ) में,एक कार्य (कंप्यूटिंग) के अंदर निष्पादन की इकाई है,[1][2] कार्य के साथ सामान्यतः एक प्रक्रिया। कंप्यूटर बहुक्रियन शब्द मुख्य रूप से कार्यविधि सेंस को संदर्भित करता है - एक ही समय में निष्पादित होने वाले कई कार्य - किन्तु एक ही समय में किए जा रहे कई कार्यों की कार्य अभिप्राय की बारीकियाँ होती हैं।

कार्य की इकाई के अर्थ में, (अर्थात् कार्य का एक-एक टुकड़ा) कार्य चरण के अनुरूप हो सकता है (स्वयं चरण, उसके निष्पादन नहीं), जबकि बैच प्रसंस्करण में व्यक्तिगत कार्य एकल के अनुरूप हो सकते हैं एक बैच में एक आइटम को संसाधित करने का चरण, या बैच में सभी आइटम को संसाधित करने का चरण। ऑनलाइन प्रणाली में, कार्य सामान्यतः एक अनुरोध (अनुरोध-प्रतिक्रिया आर्किटेक्चर में) या क्वेरी (सूचना पुनर्प्राप्ति में) के अनुरूप होते हैं, या तो संचालन का चरण, या संपूर्ण प्रणाली-वाइड संचालन।

उदाहरण

जावा (प्रोग्रामिंग भाषा) प्रोग्रामिंग लैंग्वेज में, इन दो अवधारणाओं (कार्य की इकाई और निष्पादन की इकाई) को सीधे थ्रेड्स के साथ काम करते समय मिलाया जाता है, किन्तु [1] में स्पष्ट रूप से अलग किया जाता है। (आवश्यक/संगामिति/निष्पादक .एचटीएमएल निष्पादक) रूपरेखा:

जब आप सीधे थ्रेड्स के साथ काम करते हैं, Thread तो काम की एक इकाई और इसे निष्पादित करने के लिए तंत्र दोनों के रूप में कार्य करता है। निष्पादक ढांचे में, कार्य की इकाई और निष्पादन तंत्र अलग-अलग होते हैं। कुंजी अमूर्त कार्य की इकाई है, जिसे कार्य कहा जाता है[3]

आईबीएम शब्दावली

आईबीएम शब्द का उपयोग प्रभावशाली रहा है, चूंकि शब्द की अस्पष्टता को रेखांकित करते हुए, आईबीएम शब्दावली में, कार्य के दर्जनों विशिष्ट अर्थ सम्मिलित हैं:[4]

  • कार्य की एक इकाई जो प्रक्रिया के किसी चरण का प्रतिनिधित्व करती है।
  • किसी उपकरण या प्रक्रिया द्वारा पूरा किए जाने वाले कार्य की एक इकाई है।
  • एक प्रक्रिया और प्रक्रियाएँ जो प्रक्रिया को चलाती हैं।
  • एक विशेष परिणाम प्राप्त करने के लिए डिज़ाइन किए गए कार्यों का समूह। विशिष्ट समय पर लक्ष्यों के एक समूह पर एक कार्य किया जाता है।
  • गणना की एक इकाई। समानांतर कार्य में, दो या दो से अधिक समवर्ती कार्य संदेश पासिंग और साझा मेमोरी के माध्यम से एक साथ काम करते हैं। यद्यपि प्रत्येक भौतिक या तार्किक प्रोसेसर के लिए एक कार्य आवंटित करना सामान्य बात है, शब्द कार्य और प्रोसेसर विनिमेय नहीं हैं।
  • एक गतिविधि जिसका व्यावसायिक मूल्य है, एक उपयोगकर्ता द्वारा प्रारंभ की जाती है, और सॉफ्टवेयर द्वारा की जाती है।

जेड/ओएस में विशेष रूप से, इसे ठीक से परिभाषित किया गया है:[5]

  • एक मल्टीप्रोग्रामिंग या कार्यविधि वातावरण में, एक या एक से अधिक निर्देशों के अनुक्रम को नियंत्रण प्रोग्राम द्वारा कंप्यूटर द्वारा पूरा किए जाने वाले कार्य के अव्यव के रूप में माना जाता है।

ओएस/360 में जेड/ओएस के माध्यम से शब्द कार्य मोटे तौर पर सरलतम प्रक्रिया के सामान्य है; कार्य चरण में कार्य एक पता स्थान साझा करते हैं। चूंकि, एमवीएस/ईएसए में जेड/ओएस के माध्यम से, कार्य या सेवा अनुरोध ब्लॉक (एसआरबी) की पहुँच सूची के माध्यम से अन्य पता स्थानों तक पहुँच हो सकती है।

लिनक्स कर्नेल

कार्य अवधि का उपयोग लिनक्स कर्नेल में किया जाता है (कम से कम v2.6.13 के बाद से,[6] v4.8 तक और सहित[7]) निष्पादन की इकाई को संदर्भित करने के लिए, जो प्रणाली पर अन्य कार्यों के साथ विभिन्न प्रणाली संसाधनों को साझा कर सकती है। साझा करने के स्तर के आधार पर, कार्य को पारंपरिक थ्रेड (कंप्यूटिंग) या प्रक्रिया (कंप्यूटिंग) के रूप में माना जा सकता है। का उपयोग करके कार्यों को अस्तित्व में लाया जाता है clone() प्रणाली कॉल,[8] जहां उपयोगकर्ता संसाधन साझाकरण के वांछित स्तर को निर्दिष्ट कर सकता है।

इतिहास

1960 के दशक की प्रारंभ में जॉब के एक भाग के लिए टास्क शब्द बहु क्रमादेशन के लिए था, जैसा कि 1961 के इस उदाहरण में है:

धारावाहिक मॉडल में आईबीएम 709 के कामकाज के समान स्वतंत्र विधि से एक कार्य के कार्यों को संसाधित करने की क्षमता है।.[9]

यह शब्द ओएस/360 और उत्तराधिकारी |ओएस/360 (घोषित 1964) की प्रारंभ के साथ लोकप्रिय हुआ, जिसमें ओएस/360 और उत्तराधिकारी #एमएफटी (एमएफटी) और ओएस/360 और उत्तराधिकारी #एमवीटी (एमवीटी) सम्मिलित थे। इस स्थिति में कार्यों को हल्की-फुल्की प्रक्रियाओं के साथ पहचाना गया, एक कार्य में कई कार्य सम्मिलित थे, और बाद में, कार्यों में उप-कार्य हो सकते थे (आधुनिक शब्दावली में, बाल प्रक्रियाएँ)।

आज कार्य अवधि का प्रयोग बहुत अस्पष्ट रूप से किया जाता है। उदाहरण के लिए, विंडोज़ कार्य प्रबंधक प्रक्रियाओं का प्रबंधन करता है (चल रहा है), जबकि विंडोज टास्क शेड्यूलर प्रोग्राम को भविष्य में निष्पादित करने के लिए शेड्यूल करता है, जिसे पारंपरिक रूप से नौकरी अनुसूचक के रूप में जाना जाता है, और इसका उपयोग करता है .job विस्तार। इसके विपरीत, कार्य कतार शब्द का प्रयोग सामान्यतः कार्य की इकाइयों के अर्थ में किया जाता है।

यह भी देखें

संदर्भ

  1. "What is task? - Definition from WhatIs.com". WhatIs.com. Retrieved June 11, 2015.
  2. "What are computer processes?". liutilities.com. Retrieved June 11, 2015.
  3. Bloch, Joshua. Effective Java (Third ed.). p. p. 272, Item 68.
  4. IBM Terminology: T
  5. Glossary of z/OS terms and abbreviations: T
  6. "include/linux/sched.h". GitHub.com. Linus Torvalds. August 29, 2005.
  7. "include/linux/sched.h". GitHub.com. Linus Torvalds. October 3, 2016.
  8. "clone, __clone2 - create a child process". Linux Programmer's Manual. July 17, 2016. Retrieved November 6, 2016.
  9. James Larrimore McKenney (1961). Simultaneous multiprogramming of electronic computers. p. 154.