C # - गुणा करना

threadएक कार्यक्रम के निष्पादन पथ के रूप में परिभाषित किया गया है। प्रत्येक धागा नियंत्रण के एक अद्वितीय प्रवाह को परिभाषित करता है। यदि आपके आवेदन में जटिल और समय लेने वाले संचालन शामिल हैं, तो यह अक्सर अलग-अलग निष्पादन पथ या थ्रेड्स सेट करने में सहायक होता है, जिसमें प्रत्येक थ्रेड एक विशेष कार्य करता है।

धागे हैं lightweight processes। धागे के उपयोग का एक सामान्य उदाहरण आधुनिक ऑपरेटिंग सिस्टम द्वारा समवर्ती प्रोग्रामिंग का कार्यान्वयन है। थ्रेड्स का उपयोग सीपीयू चक्र के अपव्यय को बचाता है और एक अनुप्रयोग की दक्षता बढ़ाता है।

अब तक हमने उन कार्यक्रमों को लिखा है जहां एक एकल धागा एक एकल प्रक्रिया के रूप में चलता है जो अनुप्रयोग का चल उदाहरण है। हालांकि, इस तरह से आवेदन एक समय में एक काम कर सकता है। एक समय में एक से अधिक कार्य निष्पादित करने के लिए, इसे छोटे थ्रेड में विभाजित किया जा सकता है।

धागा जीवन चक्र

एक थ्रेड का जीवन चक्र तब शुरू होता है जब System.Threading.Thread क्लास का ऑब्जेक्ट बनाया जाता है और थ्रेड समाप्त होने पर या निष्पादित होने पर समाप्त होता है।

एक सूत्र के जीवन चक्र में विभिन्न अवस्थाएँ निम्नलिखित हैं -

  • The Unstarted State - यह वह स्थिति है जब थ्रेड का उदाहरण बनाया जाता है, लेकिन स्टार्ट विधि को नहीं कहा जाता है।

  • The Ready State - यह स्थिति है जब थ्रेड सीपीयू चक्र को चलाने और प्रतीक्षा करने के लिए तैयार है।

  • The Not Runnable State - एक धागा निष्पादन योग्य नहीं है, जब

    • निद्रा विधि को कहा गया है
    • प्रतीक्षा पद्धति को कहा गया है
    • आई / ओ संचालन द्वारा अवरुद्ध
  • The Dead State - यह वह स्थिति है जब थ्रेड निष्पादन पूर्ण हो जाता है या समाप्त हो जाता है।

मुख्य सूत्र

सी # में, द System.Threading.Threadक्लास का उपयोग थ्रेड्स के साथ काम करने के लिए किया जाता है। यह एक मल्टीथ्रेड एप्लिकेशन में अलग-अलग थ्रेड बनाने और एक्सेस करने की अनुमति देता है। किसी प्रक्रिया में निष्पादित होने वाले पहले धागे को कहा जाता हैmain थ्रेड।

जब कोई C # प्रोग्राम निष्पादन शुरू करता है, तो मुख्य धागा स्वचालित रूप से बनाया जाता है। धागे का उपयोग कर बनायाThreadकक्षा को मुख्य सूत्र के बाल सूत्र कहा जाता है। आप किसी थ्रेड का उपयोग कर सकते हैंCurrentThread थ्रेड वर्ग की संपत्ति।

निम्नलिखित कार्यक्रम मुख्य धागा निष्पादन को प्रदर्शित करता है -

using System;
using System.Threading;

namespace MultithreadingApplication {
   class MainThreadProgram {
      static void Main(string[] args) {
         Thread th = Thread.CurrentThread;
         th.Name = "MainThread";
         
         Console.WriteLine("This is {0}", th.Name);
         Console.ReadKey();
      }
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

This is MainThread

थ्रेड क्लास के गुण और तरीके

निम्न तालिका कुछ सबसे अधिक इस्तेमाल किया दिखाता है properties का Thread वर्ग -

अनु क्रमांक। संपत्ति विवरण
1

CurrentContext

उस वर्तमान संदर्भ को प्राप्त करता है जिसमें थ्रेड निष्पादित हो रहा है।

2

CurrentCulture

वर्तमान थ्रेड के लिए कल्चर हो जाता है या सेट हो जाता है।

3

CurrentPrinciple

थ्रेड के वर्तमान प्रिंसिपल (भूमिका-आधारित सुरक्षा के लिए) हो जाता है या सेट हो जाता है।

4

CurrentThread

वर्तमान में चल रहे धागे हो जाता है।

5

CurrentUICulture

रन-टाइम में संस्कृति-विशिष्ट संसाधनों को देखने के लिए संसाधन प्रबंधक द्वारा उपयोग की जाने वाली वर्तमान संस्कृति को जाता है या सेट करता है।

6

ExecutionContext

एक ExecutionContext ऑब्जेक्ट प्राप्त होता है जिसमें वर्तमान थ्रेड के विभिन्न संदर्भों के बारे में जानकारी होती है।

7

IsAlive

वर्तमान थ्रेड की निष्पादन स्थिति का संकेत करने वाला मान प्राप्त करता है।

8

IsBackground

हो जाता है या यह दर्शाता है कि एक थ्रेड एक पृष्ठभूमि थ्रेड है या नहीं एक मान सेट करता है।

9

IsThreadPoolThread

एक मान बताता है कि क्या धागा प्रबंधित थ्रेड पूल से संबंधित है या नहीं।

10

ManagedThreadId

वर्तमान प्रबंधित थ्रेड के लिए एक विशिष्ट पहचानकर्ता हो जाता है।

1 1

Name

धागे का नाम हो जाता है या सेट हो जाता है।

12

Priority

किसी थ्रेड की शेड्यूलिंग प्राथमिकता को इंगित करने वाला मान प्राप्त या सेट करता है।

13

ThreadState

वर्तमान थ्रेड की स्थिति वाले मान प्राप्त करता है।

निम्न तालिका कुछ सबसे अधिक इस्तेमाल किया दिखाता है methods का Thread वर्ग -

अनु क्रमांक। विधि और विवरण
1

public void Abort()

थ्रेड को समाप्त करने की प्रक्रिया शुरू करने के लिए, थ्रेड में एक थ्रेडअर्बसेप्शन उठाता है। इस पद्धति को कॉल करना आमतौर पर थ्रेड को समाप्त करता है।

2

public static LocalDataStoreSlot AllocateDataSlot()

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

3

public static LocalDataStoreSlot AllocateNamedDataSlot(string name)

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

4

public static void BeginCriticalRegion()

एक मेजबान को सूचित करता है कि निष्पादन कोड के एक क्षेत्र में प्रवेश करने वाला है जिसमें थ्रेड एबॉर्ट या अनहेल्ड अपवाद के प्रभाव से एप्लिकेशन डोमेन में अन्य कार्यों को खतरा हो सकता है।

5

public static void BeginThreadAffinity()

एक होस्ट को सूचित करता है कि प्रबंधित कोड उन निर्देशों को निष्पादित करने वाला है जो वर्तमान भौतिक ऑपरेटिंग सिस्टम थ्रेड की पहचान पर निर्भर करते हैं।

6

public static void EndCriticalRegion()

एक मेजबान को सूचित करता है कि निष्पादन कोड के एक क्षेत्र में प्रवेश करने वाला है जिसमें थ्रेड एबॉर्ट या अनहेल्ड अपवाद के प्रभाव वर्तमान कार्य तक सीमित हैं।

7

public static void EndThreadAffinity()

एक होस्ट को सूचित करता है कि प्रबंधित कोड ने उन निर्देशों को निष्पादित करना समाप्त कर दिया है जो वर्तमान भौतिक ऑपरेटिंग सिस्टम थ्रेड की पहचान पर निर्भर करते हैं।

8

public static void FreeNamedDataSlot(string name)

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

9

public static Object GetData(LocalDataStoreSlot slot)

वर्तमान थ्रेड के वर्तमान डोमेन के भीतर, वर्तमान थ्रेड पर निर्दिष्ट स्लॉट से मान निकालता है। बेहतर प्रदर्शन के लिए, फ़ील्ड्स का उपयोग करें जो इसके बजाय थ्रेडस्टैटिक एट्रिब्यूट विशेषता के साथ चिह्नित हैं।

10

public static AppDomain GetDomain()

वर्तमान डोमेन जिसमें वर्तमान थ्रेड चल रहा है, लौटाता है।

1 1

public static AppDomain GetDomainID()

एक अद्वितीय एप्लिकेशन डोमेन पहचानकर्ता लौटाता है

12

public static LocalDataStoreSlot GetNamedDataSlot(string name)

एक नामित डेटा स्लॉट दिखता है। बेहतर प्रदर्शन के लिए, फ़ील्ड्स का उपयोग करें जो इसके बजाय थ्रेडस्टैटिक एट्रिब्यूट विशेषता के साथ चिह्नित हैं।

13

public void Interrupt()

एक थ्रेड को रोकता है जो WaitSleepJoin थ्रेड स्थिति में है।

14

public void Join()

कॉलिंग थ्रेड को तब तक ब्लॉक करता है जब तक कि एक मानक समाप्त नहीं हो जाता है, जबकि मानक COM और SendMessage पंपिंग करना जारी रहता है। इस पद्धति के अलग-अलग ओवरलोडेड रूप हैं।

15

public static void MemoryBarrier()

मेमोरी एक्सेस को निम्नानुसार सिंक्रोनाइज़ करता है: वर्तमान थ्रेड को निष्पादित करने वाला प्रोसेसर निर्देशों को इस तरह से रीऑर्डर नहीं कर सकता है कि मेमोरी से पहले मेमोरीबेरियर को कॉल करने के लिए मेमोरी एक्सेस होती है, मेमोरी एक्सेस करने के बाद मेमोरीबेरियर को कॉल का पालन करें।

16

public static void ResetAbort()

वर्तमान थ्रेड के लिए अनुरोध किया गया एक रद्द रद्द करें।

17

public static void SetData(LocalDataStoreSlot slot, Object data)

उस थ्रेड के वर्तमान डोमेन के लिए वर्तमान में चल रहे थ्रेड पर निर्दिष्ट स्लॉट में डेटा सेट करता है। बेहतर प्रदर्शन के लिए, थ्रेडस्टैटिक एट्रिब्यूट विशेषता के साथ चिह्नित फ़ील्ड का उपयोग करें।

18

public void Start()

एक धागा शुरू करता है।

19

public static void Sleep(int millisecondsTimeout)

समय की अवधि के लिए थ्रेड पॉज बनाता है।

20

public static void SpinWait(int iterations)

पुनरावृत्तियों पैरामीटर द्वारा परिभाषित समय की संख्या की प्रतीक्षा करने के लिए एक धागा का कारण बनता है

21

public static byte VolatileRead(ref byte address)

public static double VolatileRead(ref double address)

public static int VolatileRead(ref int address)

public static Object VolatileRead(ref Object address)

किसी फ़ील्ड का मान पढ़ता है। मान कंप्यूटर में किसी भी प्रोसेसर द्वारा लिखा गया नवीनतम है, चाहे प्रोसेसर की संख्या या प्रोसेसर कैश की स्थिति। इस पद्धति के अलग-अलग ओवरलोडेड रूप हैं। केवल कुछ ऊपर दिए गए हैं।

22

public static void VolatileWrite(ref byte address,byte value)

public static void VolatileWrite(ref double address, double value)

public static void VolatileWrite(ref int address, int value)

public static void VolatileWrite(ref Object address, Object value)

किसी फ़ील्ड में तुरंत एक मान लिखता है, ताकि कंप्यूटर में सभी प्रोसेसर के लिए मान दिखाई दे। इस पद्धति के अलग-अलग ओवरलोडेड रूप हैं। केवल कुछ ऊपर दिए गए हैं।

23

public static bool Yield()

कॉलिंग थ्रेड को वर्तमान प्रोसेसर पर चलाने के लिए तैयार किए गए किसी अन्य थ्रेड के लिए निष्पादन के कारण होता है। ऑपरेटिंग सिस्टम का चयन करने के लिए धागा का चयन करता है।

सूत्र बनाना

थ्रेड क्लास का विस्तार करके थ्रेड्स बनाए जाते हैं। विस्तारित थ्रेड वर्ग तब कॉल करता हैStart() बच्चे को थ्रेड निष्पादन शुरू करने की विधि।

निम्नलिखित कार्यक्रम अवधारणा को प्रदर्शित करता है -

using System;
using System.Threading;

namespace MultithreadingApplication {
   class ThreadCreationProgram {
      public static void CallToChildThread() {
         Console.WriteLine("Child thread starts");
      }
      static void Main(string[] args) {
         ThreadStart childref = new ThreadStart(CallToChildThread);
         Console.WriteLine("In Main: Creating the Child thread");
         Thread childThread = new Thread(childref);
         childThread.Start();
         Console.ReadKey();
      }
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

In Main: Creating the Child thread
Child thread starts

थ्रेड्स का प्रबंधन करना

थ्रेड क्लास थ्रेड्स के प्रबंधन के लिए विभिन्न तरीके प्रदान करता है।

निम्न उदाहरण के उपयोग को दर्शाता है sleep() एक विशिष्ट अवधि के लिए थ्रेड पॉज बनाने की विधि।

using System;
using System.Threading;

namespace MultithreadingApplication {
   class ThreadCreationProgram {
      public static void CallToChildThread() {
         Console.WriteLine("Child thread starts");
         
         // the thread is paused for 5000 milliseconds
         int sleepfor = 5000; 
         
         Console.WriteLine("Child Thread Paused for {0} seconds", sleepfor / 1000);
         Thread.Sleep(sleepfor);
         Console.WriteLine("Child thread resumes");
      }
      
      static void Main(string[] args) {
         ThreadStart childref = new ThreadStart(CallToChildThread);
         Console.WriteLine("In Main: Creating the Child thread");
         
         Thread childThread = new Thread(childref);
         childThread.Start();
         Console.ReadKey();
      }
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

In Main: Creating the Child thread
Child thread starts
Child Thread Paused for 5 seconds
Child thread resumes

थ्रेड्स को नष्ट करना

Abort() थ्रेड को नष्ट करने के लिए विधि का उपयोग किया जाता है।

रनटाइम थ्रो को रोककर ए ThreadAbortException। इस अपवाद को नहीं पकड़ा जा सकता है, नियंत्रण अंत में ब्लॉक को भेजा जाता है , यदि कोई हो।

निम्नलिखित कार्यक्रम यह दिखाता है -

using System;
using System.Threading;

namespace MultithreadingApplication {
   class ThreadCreationProgram {
      public static void CallToChildThread() {
         try {
            Console.WriteLine("Child thread starts");
            
            // do some work, like counting to 10
            for (int counter = 0; counter <= 10; counter++) {
               Thread.Sleep(500);
               Console.WriteLine(counter);
            }
            
            Console.WriteLine("Child Thread Completed");
         } catch (ThreadAbortException e) {
            Console.WriteLine("Thread Abort Exception");
         } finally {
            Console.WriteLine("Couldn't catch the Thread Exception");
         }
      }
      static void Main(string[] args) {
         ThreadStart childref = new ThreadStart(CallToChildThread);
         Console.WriteLine("In Main: Creating the Child thread");
         
         Thread childThread = new Thread(childref);
         childThread.Start();
         
         //stop the main thread for some time
         Thread.Sleep(2000);
         
         //now abort the child
         Console.WriteLine("In Main: Aborting the Child thread");
         
         childThread.Abort();
         Console.ReadKey();
      }
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

In Main: Creating the Child thread
Child thread starts
0
1
2
In Main: Aborting the Child thread
Thread Abort Exception
Couldn't catch the Thread Exception