सी # - त्वरित गाइड

C # माइक्रोसॉफ्ट द्वारा विकसित और यूरोपीय कंप्यूटर निर्माता संघ (ECMA) और अंतर्राष्ट्रीय मानक संगठन (ISO) द्वारा अनुमोदित एक आधुनिक, सामान्य प्रयोजन, वस्तु-उन्मुख प्रोग्रामिंग भाषा है।

C # को .Net फ्रेमवर्क के विकास के दौरान एंडर्स हेजलबर्ग और उनकी टीम द्वारा विकसित किया गया था।

C # को कॉमन लैंग्वेज इन्फ्रास्ट्रक्चर (CLI) के लिए डिज़ाइन किया गया है, जिसमें निष्पादन योग्य कोड और रनटाइम वातावरण शामिल है जो विभिन्न कंप्यूटर प्लेटफार्मों और आर्किटेक्चर पर विभिन्न उच्च-स्तरीय भाषाओं के उपयोग की अनुमति देता है।

निम्नलिखित कारण C # को व्यापक रूप से इस्तेमाल की जाने वाली पेशेवर भाषा बनाते हैं -

  • यह एक आधुनिक, सामान्य प्रयोजन की प्रोग्रामिंग भाषा है
  • यह ऑब्जेक्ट ओरिएंटेड है।
  • यह घटक उन्मुख है।
  • यह सीखना आसान है।
  • यह एक संरचित भाषा है।
  • यह कुशल कार्यक्रम तैयार करता है।
  • इसे विभिन्न कंप्यूटर प्लेटफॉर्म पर संकलित किया जा सकता है।
  • यह .Net फ्रेमवर्क का एक हिस्सा है।

C # की मजबूत प्रोग्रामिंग सुविधाएँ

हालाँकि C # constructs पारंपरिक उच्च-स्तरीय भाषाओं, C और C ++ का बारीकी से अनुसरण करता है और एक वस्तु-उन्मुख प्रोग्रामिंग भाषा है। यह जावा के साथ मजबूत समानता रखता है, इसमें कई मजबूत प्रोग्रामिंग विशेषताएं हैं जो इसे दुनिया भर में कई प्रोग्रामर के लिए प्रिय बनाती हैं।

निम्नलिखित सी # की कुछ महत्वपूर्ण विशेषताओं की सूची है -

  • बूलियन की स्थिति
  • स्वचालित कचरा संग्रह
  • मानक पुस्तकालय
  • विधानसभा संस्करण
  • गुण और घटनाएँ
  • डेलिगेट्स एंड इवेंट्स मैनेजमेंट
  • उपयोग में आसान जेनरिक
  • Indexers
  • सशर्त संकलन
  • सिंपल मल्टीथ्रेडिंग
  • LINQ और लैंबडा एक्सप्रेशन
  • विंडोज के साथ एकीकरण

यह विकल्प ऑनलाइन का प्रयास करें

हमने C # प्रोग्रामिंग वातावरण ऑनलाइन स्थापित किया है, ताकि आप सभी उपलब्ध उदाहरणों को ऑनलाइन संकलित और निष्पादित कर सकें। यह आपको आपके द्वारा पढ़ी गई बातों पर विश्वास दिलाता है और आपको विभिन्न विकल्पों के साथ कार्यक्रमों को सत्यापित करने में सक्षम बनाता है। किसी भी उदाहरण को संशोधित करने और इसे ऑनलाइन निष्पादित करने के लिए स्वतंत्र महसूस करें।

कोडिंगगॉन्ड पर उपलब्ध हमारे ऑनलाइन कंपाइलर का उपयोग करके निम्नलिखित उदाहरण का प्रयास करें

using System;

namespace HelloWorldApplication {
   
   class HelloWorld {

      static void Main(string[] args) {
         /* my first program in C# */
         Console.WriteLine("Hello World");
         Console.ReadKey();
      }
   }
}

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

इस अध्याय में, हम C # प्रोग्रामिंग बनाने के लिए आवश्यक उपकरणों पर चर्चा करेंगे। हमने पहले ही उल्लेख किया है कि C # .Net ढांचे का हिस्सा है और इसका उपयोग .Net अनुप्रयोगों के लेखन के लिए किया जाता है। इसलिए, C # प्रोग्राम चलाने के लिए उपलब्ध टूल पर चर्चा करने से पहले, आइए समझते हैं कि C # .net फ्रेमवर्क से कैसे संबंधित है।

.नेट फ्रेमवर्क

.Net ढांचा एक क्रांतिकारी मंच है जो आपको निम्नलिखित प्रकार के अनुप्रयोगों को लिखने में मदद करता है -

  • विंडोज अनुप्रयोगों
  • वेब अनुप्रयोग
  • वेब सेवाएं

। नेट फ्रेमवर्क एप्लिकेशन मल्टी प्लेटफॉर्म एप्लिकेशन हैं। फ्रेमवर्क को इस तरह से डिजाइन किया गया है कि इसका उपयोग निम्नलिखित भाषाओं में से किसी से भी किया जा सकता है: C #, C ++, Visual Basic, Jscript, COBOL, इत्यादि। ये सभी भाषाएं फ्रेमवर्क को एक्सेस करने के साथ-साथ एक दूसरे के साथ संवाद कर सकती हैं।

। नेट फ्रेमवर्क में कोड की एक विशाल लाइब्रेरी होती है जिसका उपयोग ग्राहक भाषाओं जैसे C # द्वारा किया जाता है। निम्नलिखित .Net ढांचे के कुछ घटक निम्नलिखित हैं -

  • सामान्य भाषा रनटाइम (सीएलआर)
  • .नेट फ्रेमवर्क क्लास लाइब्रेरी
  • सामान्य भाषा विशिष्टता
  • सामान्य प्रकार प्रणाली
  • मेटाडेटा और असेंबली
  • विंडोज फॉर्म
  • ASP.Net और ASP.Net AJAX
  • ADO.Net
  • विंडोज वर्कफ़्लो फाउंडेशन (WF)
  • विंडोज प्रेजेंटेशन फाउंडेशन
  • विंडोज कम्युनिकेशन फाउंडेशन (WCF)
  • LINQ

इनमें से प्रत्येक घटक के कार्य के लिए, कृपया ASP.Net - परिचय देखें , और प्रत्येक घटक के विवरण के लिए, कृपया Microsoft के प्रलेखन से परामर्श करें।

C # के लिए एकीकृत विकास पर्यावरण (IDE)

Microsoft C # प्रोग्रामिंग के लिए निम्नलिखित विकास उपकरण प्रदान करता है -

  • विजुअल स्टूडियो 2010 (VS)
  • दृश्य C # 2010 एक्सप्रेस (VCE)
  • विजुअल वेब डेवलपर

अंतिम दो Microsoft आधिकारिक वेबसाइट से स्वतंत्र रूप से उपलब्ध हैं। इन उपकरणों का उपयोग करके, आप सरल कमांड लाइन अनुप्रयोगों से अधिक जटिल अनुप्रयोगों तक सभी प्रकार के सी # प्रोग्राम लिख सकते हैं। आप मूल पाठ संपादक का उपयोग करके C # स्रोत कोड फ़ाइलें भी लिख सकते हैं, जैसे नोटपैड, और कमांड-लाइन कंपाइलर का उपयोग करके कोड को कोडाइल में संकलित करते हैं, जो फिर से .NET फ्रेमवर्क का एक हिस्सा है।

विज़ुअल सी # एक्सप्रेस और विज़ुअल वेब डेवलपर एक्सप्रेस संस्करण विजुअल स्टूडियो के संस्करणों को छाँट दिया जाता है और इसका स्वरूप समान होता है। वे विजुअल स्टूडियो की अधिकांश विशेषताओं को बरकरार रखते हैं। इस ट्यूटोरियल में हमने विजुअल C # 2010 एक्सप्रेस का उपयोग किया है।

आप इसे Microsoft Visual Studio से डाउनलोड कर सकते हैं । यह स्वचालित रूप से आपकी मशीन पर स्थापित हो जाता है।

नोट: आपको एक्सप्रेस संस्करण स्थापित करने के लिए एक सक्रिय इंटरनेट कनेक्शन की आवश्यकता है।

लिनक्स या मैक ओएस पर C # प्रोग्राम लिखना

हालाँकि .NET फ्रेमवर्क विंडोज ऑपरेटिंग सिस्टम पर चलता है, लेकिन कुछ वैकल्पिक संस्करण हैं जो अन्य ऑपरेटिंग सिस्टम पर काम करते हैं। Mono.NET फ्रेमवर्क का एक ओपन-सोर्स संस्करण है जिसमें एक सी # कंपाइलर शामिल है और कई ऑपरेटिंग सिस्टमों पर चलता है, जिसमें लिनक्स और मैक ओएस के विभिन्न स्वाद शामिल हैं। कृपया मोनो की जांच करें ।

मोनो का घोषित उद्देश्य न केवल Microsoft .NET अनुप्रयोगों को क्रॉस-प्लेटफ़ॉर्म पर चलाने में सक्षम है, बल्कि लिनक्स डेवलपर्स के लिए बेहतर विकास उपकरण लाने के लिए भी है। मोनो को Android, BSD, iOS, Linux, OS X, Windows, Solaris, और UNIX सहित कई ऑपरेटिंग सिस्टम पर चलाया जा सकता है।

इससे पहले कि हम C # प्रोग्रामिंग लैंग्वेज के बेसिक बिल्डिंग ब्लॉक्स का अध्ययन करें, आइए हम एक नंगे न्यूनतम C # प्रोग्राम संरचना को देखें ताकि हम इसे आगामी अध्यायों में एक संदर्भ के रूप में ले सकें।

हैलो वर्ल्ड प्रोग्राम बनाना

एसी # कार्यक्रम में निम्नलिखित भाग शामिल हैं -

  • नेमस्पेस घोषणा
  • एक कक्षा
  • कक्षा के तरीके
  • वर्ग गुण
  • एक मुख्य विधि
  • कथन और भाव
  • Comments

आइए हम एक सरल कोड को देखें जो "हैलो वर्ल्ड" शब्दों को प्रिंट करता है -

using System;

namespace HelloWorldApplication {
   
   class HelloWorld {
      
      static void Main(string[] args) {
         /* my first program in C# */
         Console.WriteLine("Hello World");
         Console.ReadKey();
      }
   }
}

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

Hello World

आइये दिए गए कार्यक्रम के विभिन्न भागों पर नजर डालते हैं -

  • कार्यक्रम की पहली पंक्ति using System; - द using कीवर्ड का उपयोग शामिल करने के लिए किया जाता है System कार्यक्रम में नाम स्थान। एक प्रोग्राम में आम तौर पर कई होते हैंusing बयान।

  • अगली पंक्ति में है namespaceघोषणा। एnamespaceकक्षाओं का एक संग्रह है। HelloWorldApplication नाम स्थान वर्ग में शामिल है HelloWorld

  • अगली पंक्ति में ए है classघोषणा, कक्षा HelloWorld में आपके प्रोग्राम का उपयोग करने वाले डेटा और पद्धति की परिभाषाएं हैं। आमतौर पर कक्षाओं में कई विधियाँ होती हैं। विधियाँ वर्ग के व्यवहार को परिभाषित करती हैं। हालाँकि, हैलोवर्ल्ड वर्ग में केवल एक विधि है Main

  • अगली पंक्ति को परिभाषित करता है Main विधि, जो है entry pointसभी सी # कार्यक्रमों के लिए। Main विधि बताती है कि निष्पादित होने पर कक्षा क्या करती है।

  • अगली पंक्ति / _...*/ को संकलक द्वारा अनदेखा किया जाता है और इसे जोड़ने के लिए रखा जाता है comments कार्यक्रम में।

  • मुख्य विधि कथन के साथ उसके व्यवहार को निर्दिष्ट करती है Console.WriteLine("Hello World");

    राइटलाइन सिस्टम नामस्थान में परिभाषित कंसोल वर्ग की एक विधि है । यह कथन "हैलो, वर्ल्ड!" संदेश का कारण बनता है। स्क्रीन पर प्रदर्शित किया जाना है।

  • आखिरी लाइन Console.ReadKey();VS.NET उपयोगकर्ताओं के लिए है। यह प्रोग्राम को एक कुंजी प्रेस की प्रतीक्षा करता है और यह दृश्य स्टूडियो .NET से प्रोग्राम को लॉन्च करने पर स्क्रीन को जल्दी से चलने और बंद होने से रोकता है।

यह निम्नलिखित बातों पर ध्यान देने योग्य है -

  • C # केस संवेदी है।
  • सभी बयान और अभिव्यक्ति एक अर्धविराम (;) के साथ समाप्त होनी चाहिए।
  • कार्यक्रम निष्पादन मुख्य विधि से शुरू होता है।
  • जावा के विपरीत, प्रोग्राम फ़ाइल नाम वर्ग के नाम से अलग हो सकता है।

कार्यक्रम का संकलन और निष्पादन

यदि आप C # प्रोग्राम को कंपाइल और निष्पादित करने के लिए Visual Studio.Net का उपयोग कर रहे हैं, तो निम्न चरण अपनाएं -

  • Visual Studio प्रारंभ करें।

  • मेनू बार पर, फ़ाइल -> नया -> प्रोजेक्ट चुनें।

  • टेम्प्लेट से विजुअल C # चुनें, और फिर विंडोज चुनें।

  • कंसोल एप्लिकेशन चुनें।

  • अपने प्रोजेक्ट के लिए एक नाम निर्दिष्ट करें और ओके बटन पर क्लिक करें।

  • यह समाधान एक्सप्लोरर में एक नई परियोजना बनाता है।

  • कोड संपादक में कोड लिखें।

  • प्रोजेक्ट को निष्पादित करने के लिए Run बटन पर क्लिक करें या F5 कुंजी दबाएँ। एक कमांड प्रॉम्प्ट विंडो दिखाई देती है जिसमें हैलो वर्ल्ड की लाइन है।

आप Visual Studio IDE के बजाय कमांड-लाइन का उपयोग करके C # प्रोग्राम संकलित कर सकते हैं -

  • एक टेक्स्ट एडिटर खोलें और उपर्युक्त कोड जोड़ें।

  • फ़ाइल को इस रूप में सहेजें helloworld.cs

  • कमांड प्रॉम्प्ट टूल खोलें और उस डायरेक्टरी पर जाएं जहां आपने फाइल सेव की थी।

  • प्रकार csc helloworld.cs और अपना कोड संकलित करने के लिए एंटर दबाएं।

  • यदि आपके कोड में कोई त्रुटि नहीं है, तो कमांड प्रॉम्प्ट आपको अगली पंक्ति में ले जाता है और उत्पन्न करता है helloworld.exe निष्पादनीय फाइल।

  • प्रकार helloworld अपने कार्यक्रम को निष्पादित करने के लिए।

  • आप आउटपुट हैलो वर्ल्ड को स्क्रीन पर प्रिंट करके देख सकते हैं।

C # एक ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज है। ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग पद्धति में, एक प्रोग्राम में विभिन्न ऑब्जेक्ट होते हैं जो क्रियाओं के माध्यम से एक-दूसरे के साथ बातचीत करते हैं। किसी वस्तु को लेने वाली क्रियाओं को विधियाँ कहा जाता है। कहा जाता है कि एक ही तरह की वस्तुएं एक ही प्रकार की होती हैं या एक ही वर्ग की होती हैं।

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

आइए हम एक आयत वर्ग के कार्यान्वयन को देखें और C # मूल वाक्यविन्यास पर चर्चा करें -

using System;

namespace RectangleApplication {
   
   class Rectangle {
      // member variables
      double length;
      double width;
      
      public void Acceptdetails() {
         length = 4.5;    
         width = 3.5;
      }
      
      public double GetArea() {
         return length * width; 
      }
      
      public void Display() {
         Console.WriteLine("Length: {0}", length);
         Console.WriteLine("Width: {0}", width);
         Console.WriteLine("Area: {0}", GetArea());
      }
   }
   
   class ExecuteRectangle {
   
      static void Main(string[] args) {
         Rectangle r = new Rectangle();
         r.Acceptdetails();
         r.Display();
         Console.ReadLine(); 
      }
   }
}

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

Length: 4.5
Width: 3.5
Area: 15.75

कीवर्ड का उपयोग कर

किसी भी C # प्रोग्राम में पहला स्टेटमेंट है

using System;

usingकार्यक्रम में नामस्थान सहित कीवर्ड का उपयोग किया जाता है। एक प्रोग्राम में कई स्टेटमेंट्स का इस्तेमाल किया जा सकता है।

वर्ग कीवर्ड

class कीवर्ड का उपयोग वर्ग घोषित करने के लिए किया जाता है।

C # में टिप्पणियाँ

टिप्पणियाँ कोड को समझाने के लिए उपयोग की जाती हैं। संकलक टिप्पणी प्रविष्टियों की उपेक्षा करते हैं। C # कार्यक्रमों में बहुस्तरीय टिप्पणियां / * से शुरू होती हैं और पात्रों के साथ समाप्त होती हैं * / जैसा कि नीचे दिखाया गया है -

/* This program demonstrates
The basic syntax of C# programming 
Language */

एकल-लाइन टिप्पणियों को '//' चिह्न द्वारा दर्शाया गया है। उदाहरण के लिए,

}//end class Rectangle

सदस्य चर

चर एक वर्ग के गुण या डेटा सदस्य हैं, जिनका उपयोग डेटा संग्रहीत करने के लिए किया जाता है। पूर्ववर्ती कार्यक्रम में, आयत वर्ग में लंबाई और चौड़ाई नाम के दो सदस्य चर हैं ।

सदस्य कार्य

कार्य एक विशिष्ट कार्य करने वाले कथनों के समूह हैं। वर्ग के सदस्य कार्यों को कक्षा के भीतर घोषित किया जाता है। हमारे नमूना वर्ग आयत में तीन सदस्य कार्य शामिल हैं: AcceptDetails , GetArea और Display

तुरंत क्लास लगाना

पूर्ववर्ती कार्यक्रम में, क्लास ExecuteRectangle में मेन () विधि शामिल है और आयत वर्ग को इंस्टेंटेट करता है ।

पहचानकर्ता

एक पहचानकर्ता एक वर्ग, चर, फ़ंक्शन या किसी अन्य उपयोगकर्ता-निर्धारित आइटम की पहचान करने के लिए उपयोग किया जाने वाला नाम है। C # में कक्षाओं के नामकरण के मूल नियम इस प्रकार हैं -

  • एक नाम एक अक्षर से शुरू होना चाहिए जो अक्षरों, अंकों (0 - 9) या अंडरस्कोर के अनुक्रम के बाद हो सकता है। किसी पहचानकर्ता का पहला वर्ण कोई अंक नहीं हो सकता है।

  • इसमें कोई एम्बेडेड स्पेस या प्रतीक नहीं होना चाहिए जैसे कि? - +! @ #% ^ & * () [] {}। ; : "'/ और \। हालांकि, एक अंडरस्कोर (_) का उपयोग किया जा सकता है।

  • यह C # कीवर्ड नहीं होना चाहिए।

C # कीवर्ड

कीवर्ड सी # संकलक के लिए पूर्वनिर्धारित शब्द हैं। इन खोजशब्दों को पहचानकर्ता के रूप में उपयोग नहीं किया जा सकता है। हालाँकि, यदि आप इन कीवर्ड का पहचानकर्ता के रूप में उपयोग करना चाहते हैं, तो आप कीवर्ड को @ वर्ण से जोड़ सकते हैं।

C # में, कोड के संदर्भ में कुछ पहचानकर्ताओं का विशेष अर्थ है, जैसे कि प्राप्त और सेट को प्रासंगिक कीवर्ड कहा जाता है।

निम्न तालिका आरक्षित कीवर्ड और प्रासंगिक कीवर्ड को C # में सूचीबद्ध करती है -

आरक्षित खोजशब्द
सार जैसा आधार bool टूटना बाइट मामला
पकड़ चार जाँच कक्षा स्थिरांक जारी रखें दशमलव
चूक प्रतिनिधि कर दोहरा अन्य enum प्रतिस्पर्धा
मुखर निर्वासन असत्य आखिरकार तय नाव के लिये
प्रत्येक के लिए के लिए जाओ अगर अंतर्निहित में में (सामान्य संशोधक) पूर्णांक
इंटरफेस अंदर का है लॉक लंबा नाम स्थान नया
शून्य वस्तु ऑपरेटर बाहर बाहर (सामान्य संशोधक) अवहेलना पैरामीटर
निजी संरक्षित जनता सिफ़ पढ़िये संदर्भ वापसी sbyte
सील कम इस आकार का stackalloc स्थिर तार struct
स्विच यह फेंकना सच प्रयत्न प्रकार का uint
Ulong अनियंत्रित असुरक्षित ushort का उपयोग करते हुए वास्तविक शून्य
परिवर्तनशील जबकि
प्रासंगिक कीवर्ड
जोड़ना उपनाम आरोही उतरते गतिशील से प्राप्त
वैश्विक समूह जांच में शामिल होने के लश्कर द्वारा आदेश आंशिक (प्रकार)
आंशिक
(विधि)
हटाना चुनते हैं सेट

C # में चर, निम्न प्रकारों में वर्गीकृत किए गए हैं -

  • मान प्रकार
  • संदर्भ प्रकार
  • सूचक प्रकार

मान प्रकार

मान प्रकार चर को सीधे मान दिया जा सकता है। वे वर्ग से निकले हैं System.ValueType

मान प्रकारों में सीधे डेटा होता है। कुछ उदाहरण निम्न हैंint, char, and float, जो क्रमशः संख्या, अक्षर, और फ़्लोटिंग पॉइंट नंबर संग्रहीत करता है। जब आप घोषणा करते हैंint प्रकार, सिस्टम मान को संग्रहीत करने के लिए मेमोरी आवंटित करता है।

निम्न तालिका C # 2010 में उपलब्ध मूल्य प्रकारों को सूचीबद्ध करती है -

प्रकार प्रतिनिधित्व करता है रेंज डिफ़ॉल्ट मान
bool बूलियन मूल्य सही या गलत असत्य
बाइट 8-बिट अहस्ताक्षरित पूर्णांक 0 से 255 रु 0
चार 16-बिट यूनिकोड चरित्र U +0000 से U + ffff '\ 0'
दशमलव 28-29 महत्वपूर्ण अंकों के साथ 128-बिट सटीक दशमलव मान -7.9 x 10 28 से 7.9 x 10 28 ) / 10 0 से 28 0.0M
दोहरा 64-बिट डबल-सटीक फ़्लोटिंग पॉइंट प्रकार (+/-) 5.0 x 10 -324 से (+/-) 1.7 x 10 308 0.0D
नाव 32-बिट एकल-सटीक फ़्लोटिंग पॉइंट प्रकार -3.4 x 10 38 से + 3.4 x 10 38 0.0F
पूर्णांक 32-बिट हस्ताक्षरित पूर्णांक प्रकार -2,147,483,648 से 2,147,483,647 0
लंबा 64-बिट हस्ताक्षरित पूर्णांक प्रकार -9,223,372,036,854,775,808 से 9,223,372,036,854,775,807 0L
sbyte 8-बिट हस्ताक्षरित पूर्णांक प्रकार -128 से 127 0
कम 16-बिट हस्ताक्षरित पूर्णांक प्रकार -32,768 से 32,767 0
uint 32-बिट अहस्ताक्षरित पूर्णांक प्रकार 0 से 4,294,967,295 रु 0
Ulong 64-बिट अहस्ताक्षरित पूर्णांक प्रकार 0 से 18,446,744,073,709,551,615 0
ushort 16-बिट अहस्ताक्षरित पूर्णांक प्रकार 0 से 65,535 रु 0

किसी विशेष प्लेटफ़ॉर्म पर किसी प्रकार या चर का सटीक आकार प्राप्त करने के लिए, आप निम्न का उपयोग कर सकते हैं sizeofतरीका। एक्सप्रेशन साइज़ोफ़ (प्रकार) ऑब्जेक्ट के स्टोरेज साइज़ या बाइट्स में टाइप करता है। किसी भी मशीन पर int प्रकार का आकार प्राप्त करने के लिए एक उदाहरण निम्नलिखित है -

using System;

namespace DataTypeApplication {
   
   class Program {

      static void Main(string[] args) {
         Console.WriteLine("Size of int: {0}", sizeof(int));
         Console.ReadLine();
      }
   }
}

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

Size of int: 4

संदर्भ प्रकार

संदर्भ प्रकारों में चर में संग्रहीत वास्तविक डेटा नहीं होता है, लेकिन वे चर के संदर्भ में होते हैं।

दूसरे शब्दों में, वे एक मेमोरी लोकेशन को संदर्भित करते हैं। कई चर का उपयोग करते हुए, संदर्भ प्रकार एक मेमोरी स्थान को संदर्भित कर सकते हैं। यदि स्मृति स्थान में डेटा चर में से एक द्वारा बदल दिया जाता है, तो दूसरा चर स्वचालित रूप से मूल्य में इस परिवर्तन को दर्शाता है। इसका उदाहरणbuilt-in संदर्भ प्रकार हैं: object, dynamic, तथा string

वस्तु प्रकार

Object TypeC # सामान्य प्रकार सिस्टम (CTS) में सभी डेटा प्रकारों के लिए अंतिम आधार वर्ग है। ऑब्जेक्ट System.Object क्लास के लिए एक अन्य नाम है। ऑब्जेक्ट प्रकारों को किसी भी अन्य प्रकार, मान प्रकार, संदर्भ प्रकार, पूर्वनिर्धारित या उपयोगकर्ता-परिभाषित प्रकार के मान निर्दिष्ट किए जा सकते हैं। हालाँकि, मान निर्दिष्ट करने से पहले, इसे टाइप रूपांतरण की आवश्यकता होती है।

जब एक मान प्रकार को ऑब्जेक्ट प्रकार में परिवर्तित किया जाता है, तो इसे कहा जाता है boxing और दूसरी ओर, जब किसी वस्तु प्रकार को एक मूल्य प्रकार में परिवर्तित किया जाता है, तो उसे कहा जाता है unboxing

object obj;
obj = 100; // this is boxing

गतिशील प्रकार

आप डायनामिक डेटा टाइप वैरिएबल में किसी भी प्रकार के मूल्य को स्टोर कर सकते हैं। इस प्रकार के चरों के लिए टाइप चेकिंग रन-टाइम पर होती है।

डायनेमिक प्रकार घोषित करने के लिए सिंटैक्स है -

dynamic <variable_name> = value;

उदाहरण के लिए,

dynamic d = 20;

गतिशील प्रकार ऑब्जेक्ट प्रकारों के समान होते हैं सिवाय इसके कि ऑब्जेक्ट प्रकार चर के लिए जाँच संकलन समय पर होता है, जबकि गतिशील प्रकार चर के लिए रन समय पर होता है।

स्ट्रिंग प्रकार

String Typeआपको चर के लिए कोई भी स्ट्रिंग मान निर्दिष्ट करने की अनुमति देता है। स्ट्रिंग प्रकार System.String वर्ग के लिए एक उपनाम है। यह वस्तु प्रकार से लिया गया है। एक स्ट्रिंग प्रकार का मान दो रूपों में स्ट्रिंग शाब्दिक का उपयोग करके सौंपा जा सकता है: उद्धृत और @quoted।

उदाहरण के लिए,

String str = "Tutorials Point";

एक @ स्ट्रिंग स्ट्रिंग शाब्दिक इस प्रकार दिखता है -

@"Tutorials Point";

उपयोगकर्ता-परिभाषित संदर्भ प्रकार हैं: वर्ग, इंटरफ़ेस या प्रतिनिधि। हम बाद के अध्याय में इन प्रकारों पर चर्चा करेंगे।

सूचक प्रकार

पॉइंटर प्रकार चर दूसरे प्रकार के मेमोरी एड्रेस को स्टोर करते हैं। C # में पॉइंटर्स C या C ++ में पॉइंटर्स की तरह ही क्षमता रखते हैं।

पॉइंटर प्रकार घोषित करने के लिए सिंटैक्स है -

type* identifier;

उदाहरण के लिए,

char* cptr;
int* iptr;

हम 'असुरक्षित कोड्स' अध्याय में सूचक प्रकारों पर चर्चा करेंगे।

प्रकार रूपांतरण एक प्रकार के डेटा को दूसरे प्रकार में परिवर्तित कर रहा है। इसे टाइप कास्टिंग के नाम से भी जाना जाता है। C # में, टाइप कास्टिंग के दो रूप हैं -

  • Implicit type conversion- ये रूपांतरण टाइप-सी तरीके से C # द्वारा किए जाते हैं। उदाहरण के लिए, छोटे से बड़े अभिन्न प्रकारों और व्युत्पन्न वर्ग से आधार कक्षाओं तक के रूपांतरण हैं।

  • Explicit type conversion- ये रूपांतरण पूर्व-निर्धारित कार्यों का उपयोग करके उपयोगकर्ताओं द्वारा स्पष्ट रूप से किया जाता है। स्पष्ट रूपांतरणों में एक कास्ट ऑपरेटर की आवश्यकता होती है।

निम्न उदाहरण एक स्पष्ट प्रकार का रूपांतरण दिखाता है -

using System;

namespace TypeConversionApplication {

   class ExplicitConversion {
   
      static void Main(string[] args) {
         double d = 5673.74; 
         int i;
         
         // cast double to int.
         i = (int)d;
         Console.WriteLine(i);
         Console.ReadKey();
      }
   }
}

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

5673

C # प्रकार रूपांतरण विधियाँ

C # निम्नलिखित अंतर्निहित प्रकार के रूपांतरण के तरीके प्रदान करता है -

अनु क्रमांक। तरीके और विवरण
1

ToBoolean

एक प्रकार को बूलियन मान में परिवर्तित करता है, जहां संभव हो।

2

ToByte

एक प्रकार को बाइट में परिवर्तित करता है।

3

ToChar

एक प्रकार को एकल यूनिकोड वर्ण में परिवर्तित करता है, जहाँ संभव हो।

4

ToDateTime

एक प्रकार (पूर्णांक या स्ट्रिंग प्रकार) को दिनांक-समय संरचनाओं में परिवर्तित करता है।

5

ToDecimal

एक फ़्लोटिंग बिंदु या पूर्णांक प्रकार को दशमलव प्रकार में परिवर्तित करता है।

6

ToDouble

एक प्रकार को एक दोहरे प्रकार में परिवर्तित करता है।

7

ToInt16

एक प्रकार को 16-बिट पूर्णांक में परिवर्तित करता है।

8

ToInt32

एक प्रकार को 32-बिट पूर्णांक में परिवर्तित करता है।

9

ToInt64

एक प्रकार को 64-बिट पूर्णांक में परिवर्तित करता है।

10

ToSbyte

एक प्रकार को एक हस्ताक्षरित बाइट प्रकार में परिवर्तित करता है।

1 1

ToSingle

एक प्रकार को छोटे फ्लोटिंग पॉइंट नंबर में परिवर्तित करता है।

12

ToString

एक प्रकार को एक स्ट्रिंग में परिवर्तित करता है।

13

ToType

एक प्रकार को एक निर्दिष्ट प्रकार में रूपांतरित करता है।

14

ToUInt16

एक प्रकार को एक अहस्ताक्षरित int प्रकार में परिवर्तित करता है।

15

ToUInt32

एक प्रकार को एक अहस्ताक्षरित लंबे प्रकार में परिवर्तित करता है।

16

ToUInt64

एक प्रकार को एक अहस्ताक्षरित बड़े पूर्णांक में परिवर्तित करता है।

निम्न उदाहरण विभिन्न प्रकार के प्रकार को स्ट्रिंग प्रकार में परिवर्तित करता है -

using System;

namespace TypeConversionApplication {
   
   class StringConversion {
      
      static void Main(string[] args) {
         int i = 75;
         float f = 53.005f;
         double d = 2345.7652;
         bool b = true;

         Console.WriteLine(i.ToString());
         Console.WriteLine(f.ToString());
         Console.WriteLine(d.ToString());
         Console.WriteLine(b.ToString());
         Console.ReadKey();
            
      }
   }
}

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

75
53.005
2345.7652
True

एक चर कुछ भी नहीं है लेकिन एक भंडारण क्षेत्र को दिया गया नाम है जो हमारे कार्यक्रमों में हेरफेर कर सकता है। C # के प्रत्येक चर का एक विशिष्ट प्रकार होता है, जो चर की स्मृति के आकार और लेआउट को निर्धारित करता है, उस स्मृति के भीतर संग्रहीत किए जा सकने वाले मानों की श्रेणी और परिचालनों पर लागू किए जा सकने वाले संचालन का सेट।

C # में दिए गए मूल मूल्य प्रकारों को निम्नानुसार वर्गीकृत किया जा सकता है -

प्रकार उदाहरण
अभिन्न प्रकार sbyte, बाइट, शॉर्ट, ushort, int, uint, लॉन्ग, अलॉन्ग, और चार
फ्लोटिंग पॉइंट प्रकार फ्लोट और डबल
दशम प्रकार दशमलव
बुलियन प्रकार सच या गलत मान, जैसा कि असाइन किया गया है
अशक्त प्रकार के अशक्त डेटा प्रकार

C # भी चर के अन्य प्रकार के मान को परिभाषित करने की अनुमति देता है enum और संदर्भ प्रकार के चर जैसे class, जिसे हम बाद के अध्यायों में शामिल करेंगे।

चर को परिभाषित करना

C # में चर परिभाषा के लिए सिंटैक्स है -

<data_type> <variable_list>;

यहां, data_type को एक मान्य C # डेटा प्रकार होना चाहिए जिसमें चार, इंट, फ्लोट, डबल, या कोई भी उपयोगकर्ता-निर्धारित डेटा प्रकार शामिल है, और वेरिएबल_लिस्ट में अल्पविराम द्वारा अलग किए गए एक या अधिक पहचानकर्ता नाम शामिल हो सकते हैं।

कुछ मान्य चर परिभाषाएँ यहाँ दिखाई गई हैं -

int i, j, k;
char c, ch;
float f, salary;
double d;

आप परिभाषा के समय एक चर को आरंभ कर सकते हैं -

int i = 100;

वैरिएबल की शुरुआत

चर एक अभिव्यक्ति के बाद एक बराबर चिह्न के साथ आरंभीकृत (एक मान निर्दिष्ट) हैं। आरंभीकरण का सामान्य रूप है -

variable_name = value;

चर को उनकी घोषणा में आरंभीकृत किया जा सकता है। इनिशियलाइज़र में एक समरूप चिह्न होता है जिसके बाद एक स्थिर अभिव्यक्ति होती है -

<data_type> <variable_name> = value;

कुछ उदाहरण हैं -

int d = 3, f = 5;    /* initializing d and f. */
byte z = 22;         /* initializes z. */
double pi = 3.14159; /* declares an approximation of pi. */
char x = 'x';        /* the variable x has the value 'x'. */

चर को ठीक से शुरू करने के लिए यह एक अच्छा प्रोग्रामिंग अभ्यास है, अन्यथा कभी-कभी प्रोग्राम अप्रत्याशित परिणाम उत्पन्न कर सकता है।

निम्नलिखित उदाहरण विभिन्न प्रकार के चर का उपयोग करता है -

using System;

namespace VariableDefinition {

   class Program {
   
      static void Main(string[] args) {
         short a;
         int b ;
         double c;

         /* actual initialization */
         a = 10;
         b = 20;
         c = a + b;
         Console.WriteLine("a = {0}, b = {1}, c = {2}", a, b, c);
         Console.ReadLine();
      }
   }
}

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

a = 10, b = 20, c = 30

उपयोगकर्ता से मानों को स्वीकार करना

Console कक्षा में System नाम स्थान एक फ़ंक्शन प्रदान करता है ReadLine() उपयोगकर्ता से इनपुट स्वीकार करने के लिए और इसे एक चर में संग्रहीत करें।

उदाहरण के लिए,

int num;
num = Convert.ToInt32(Console.ReadLine());

कार्यक्रम Convert.ToInt32() डेटा टाइप करने के लिए उपयोगकर्ता द्वारा दर्ज किए गए डेटा को धर्मान्तरित करता है, क्योंकि Console.ReadLine() स्ट्रिंग प्रारूप में डेटा को स्वीकार करता है।

C # में लैवल्यू और रिवेल्यू एक्सप्रेशंस

C # में दो तरह के भाव हैं -

  • lvalue - एक अभिव्यक्ति जो एक लवल्यू है, वह एक असाइनमेंट के बाएं-हाथ या दाईं ओर के रूप में दिखाई दे सकती है।

  • rvalue - एक अभिव्यक्ति जो एक लकीर है वह दाईं ओर दिखाई दे सकती है - लेकिन एक असाइनमेंट के बाईं ओर नहीं।

विविधताएं अंतराल हैं और इसलिए वे एक असाइनमेंट के बाईं ओर दिखाई दे सकते हैं। न्यूमेरिकल शाब्दिक नियम हैं और इसलिए उन्हें असाइन नहीं किया जा सकता है और वे बाईं ओर नहीं दिखाई दे सकते हैं। निम्नलिखित एक मान्य C # कथन है -

int g = 20;

लेकिन निम्नलिखित एक मान्य कथन नहीं है और यह संकलन-समय त्रुटि उत्पन्न करेगा -

10 = 20;

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

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

पूर्णांक का साहित्य

पूर्णांक शाब्दिक एक दशमलव, या हेक्साडेसिमल स्थिरांक हो सकता है। एक उपसर्ग आधार या मूलांक निर्दिष्ट करता है: हेक्साडेसिमल के लिए 0x या 0X, और दशमलव के लिए कोई उपसर्ग आईडी नहीं है।

एक पूर्णांक शाब्दिक में एक प्रत्यय भी हो सकता है जो क्रमशः अहस्ताक्षरित और लंबे समय के लिए यू और एल का संयोजन है। प्रत्यय अपरकेस या लोअरकेस हो सकता है और किसी भी क्रम में हो सकता है।

यहाँ पूर्णांक शाब्दिक के कुछ उदाहरण हैं -

212         /* Legal */
215u        /* Legal */
0xFeeL      /* Legal */

विभिन्न प्रकार के पूर्णांक शाब्दिक अन्य उदाहरण हैं -

85         /* decimal */
0x4b       /* hexadecimal */
30         /* int */
30u        /* unsigned int */
30l        /* long */
30ul       /* unsigned long */

फ़्लोटिंग-पॉइंट लिटरल्स

फ्लोटिंग-पॉइंट शाब्दिक में एक पूर्णांक भाग, एक दशमलव बिंदु, एक आंशिक भाग और एक घातांक भाग होता है। आप अस्थायी बिंदु शाब्दिक या तो दशमलव रूप या घातांक रूप में दर्शा सकते हैं।

यहाँ फ़्लोटिंग पॉइंट शाब्दिक के कुछ उदाहरण दिए गए हैं -

3.14159       /* Legal */
314159E-5F    /* Legal */
510E          /* Illegal: incomplete exponent */
210f          /* Illegal: no decimal or exponent */
.e55          /* Illegal: missing integer or fraction */

दशमलव रूप में प्रतिनिधित्व करते समय, आपको दशमलव बिंदु, प्रतिपादक या दोनों को शामिल करना होगा; और घातीय रूप का उपयोग करते समय आपको पूर्णांक भाग, आंशिक भाग या दोनों को शामिल करना होगा। हस्ताक्षरित प्रतिपादक को ई या ई द्वारा प्रस्तुत किया जाता है।

चरित्र कांस्टेंट

चरित्र के शब्द एकल उद्धरणों में संलग्न हैं। उदाहरण के लिए, 'x' और चार प्रकार के सरल चर में संग्रहित किया जा सकता है। एक चरित्र शाब्दिक एक सादे चरित्र (जैसे 'x'), एक एस्केप सीक्वेंस (जैसे '\ t'), या एक सार्वभौमिक चरित्र (जैसे '\ u02C0') हो सकता है।

जब वे बैकस्लैश से पहले होते हैं तो सी # में कुछ पात्र होते हैं। उनका विशेष अर्थ है और उनका उपयोग newline (\ n) या टैब (\ t) की तरह प्रतिनिधित्व करने के लिए किया जाता है। यहाँ, इस तरह के कुछ भागने अनुक्रम कोड की एक सूची है -

निकास का क्रम जिसका अर्थ है
\\ \ चरित्र
\ ' 'चरित्र
\ " “चरित्र
\? ? चरित्र
\ए चेतावनी या घंटी
\ b बैकस्पेस
\ च फ़ीड बनाएं
\ n नई पंक्ति
\ r कैरिज रिटर्न
\ t क्षैतिज टैब
\ v लंबवत टैब
\ xhh। । । एक या अधिक अंकों की हेक्साडेसिमल संख्या

निम्नलिखित कुछ अनुक्रम अनुक्रम दिखाने के लिए उदाहरण है -

using System;

namespace EscapeChar {

   class Program {
   
      static void Main(string[] args) {
         Console.WriteLine("Hello\tWorld\n\n");
         Console.ReadLine();
      }
   }
}

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

Hello   World

स्ट्रिंग लिटरल

स्ट्रिंग शाब्दिक या स्थिरांक दोहरे उद्धरण चिह्नों में "" या @ "" के साथ संलग्न हैं। एक तार में वर्ण होते हैं जो वर्ण शाब्दिक के समान होते हैं: सादे वर्ण, बच के क्रम और सार्वभौमिक वर्ण।

आप स्ट्रिंग शाब्दिक का उपयोग करके कई लाइनों में एक लंबी लाइन को तोड़ सकते हैं और व्हाट्सएप का उपयोग करके भागों को अलग कर सकते हैं।

यहाँ स्ट्रिंग शाब्दिकों के कुछ उदाहरण दिए गए हैं। तीनों रूप समान तार हैं।

"hello, dear"
"hello, \
dear"
"hello, " "d" "ear"
@"hello dear"

लगातार परिभाषित करना

लगातार का उपयोग कर परिभाषित किया गया है constकीवर्ड। एक स्थिरांक को परिभाषित करने के लिए सिंटैक्स है -

const <data_type> <constant_name> = value;

निम्न प्रोग्राम आपके प्रोग्राम में एक स्थिरांक को परिभाषित और उपयोग करता है -

using System;

namespace DeclaringConstants {

    class Program {
    
        static void Main(string[] args) {
            const double pi = 3.14159;   
            
            // constant declaration 
            double r;
            Console.WriteLine("Enter Radius: ");
            r = Convert.ToDouble(Console.ReadLine());
            double areaCircle = pi * r * r;
            Console.WriteLine("Radius: {0}, Area: {1}", r, areaCircle);
            Console.ReadLine();
        }
    }
}

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

Enter Radius: 
3
Radius: 3, Area: 28.27431

एक ऑपरेटर एक प्रतीक है जो संकलक को विशिष्ट गणितीय या तार्किक जोड़तोड़ करने के लिए कहता है। C # में अंतर्निहित ऑपरेटरों का समृद्ध सेट है और निम्नलिखित प्रकार के ऑपरेटर प्रदान करता है -

  • अंकगणितीय आपरेटर
  • संबंधपरक संकारक
  • लॉजिकल ऑपरेटर्स
  • बिटवाइज ऑपरेटर्स
  • असाइनमेंट ऑपरेटर्स
  • विविध संचालक

यह ट्यूटोरियल अंकगणित, संबंधपरक, तार्किक, बिटवाइज़, असाइनमेंट और अन्य ऑपरेटरों को एक-एक करके समझाता है।

अंकगणितीय आपरेटर

निम्नलिखित तालिका सी # द्वारा समर्थित सभी अंकगणितीय ऑपरेटरों को दिखाती है। चर मान लेंA 10 और चर रखता है B 20 तब रखती है -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
+ दो ऑपरेंड जोड़ता है ए + बी = 30
- पहले से दूसरे ऑपरेंड को घटाता है ए - बी = -10
* दोनों ऑपरेंड को गुणा करता है ए * बी = 200
/ डी-न्यूमेरियर द्वारा अंशों को विभाजित करता है बी / ए = २
% मापांक ऑपरेटर और पूर्णांक विभाजन के बाद शेष ब% ए = ०
++ वृद्धि ऑपरेटर एक के बाद पूर्णांक मान बढ़ाता है ए ++ = 11
- कमी ऑपरेटर एक से पूर्णांक मान घटाता है ए-- = ९

संबंधपरक संकारक

निम्नलिखित तालिका सी # द्वारा समर्थित सभी रिलेशनल ऑपरेटरों को दिखाती है। चर मान लेंA 10 और चर रखता है B 20 रखती है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
== जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। (ए == बी) सच नहीं है।
! = जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि मान बराबर नहीं हैं तो स्थिति सत्य हो जाती है। (ए! = बी) सच है।
> यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है, यदि हाँ, तो स्थिति सत्य है। (ए> बी) सच नहीं है।
< यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम है, यदि हाँ, तो स्थिति सही है। (ए <बी) सच है।
> = जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से अधिक या उसके बराबर है, यदि हाँ तो स्थिति सच हो जाती है। (ए> = बी) सच नहीं है।
<= जाँच करता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है। (ए <= बी) सच है।

लॉजिकल ऑपरेटर्स

निम्नलिखित तालिका सी # द्वारा समर्थित सभी तार्किक ऑपरेटरों को दिखाती है। चर मान लेंA बूलियन मान को सही और परिवर्तनशील रखता है B बूलियन मान को गलत रखता है, फिर -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
&& जिसे लॉजिकल एंड ऑपरेटर कहा जाता है। यदि दोनों ऑपरेंड नॉन जीरो हैं तो कंडीशन सही हो जाती है। (A && B) गलत है।
|| जिसे लॉजिकल या ऑपरेटर कहा जाता है। यदि दोनों संचालकों में से कोई भी गैर शून्य है तो स्थिति सत्य हो जाती है। (ए || बी) सच है
! जिसे लॉजिकल नॉट ऑपरेटर कहा जाता है। उपयोग अपने ऑपरेंड की तार्किक स्थिति को उलट देता है। यदि कोई शर्त सही है तो लॉजिकल नॉट ऑपरेटर गलत साबित करेगा। ! (A && B) सत्य है।

बिटवाइज ऑपरेटर्स

बिटवाइज ऑपरेटर बिट्स पर काम करता है और बिट ऑपरेशन द्वारा बिट करता है। सत्य सारणी &,; और ^ के लिए निम्नानुसार हैं -

पी क्यू पी क्यू पी | क्यू p ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

मान लें कि ए = 60; और बी = 13; फिर द्विआधारी प्रारूप में वे इस प्रकार हैं -

ए = 0011 1100

B = 0000 1101

-------------------

A & B = 0000 1100

ए | बी = ००११ ११०१

ए ^ बी = 0011 0001

~ ए = ११०० ००११

C # द्वारा समर्थित बिटवाइज़ ऑपरेटर निम्न तालिका में सूचीबद्ध हैं। चर ए मान लें 60 और चर बी 13 रखता है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
और बाइनरी और ऑपरेटर परिणाम के लिए थोड़ा सा कॉपी करता है यदि यह दोनों ऑपरेंड में मौजूद है। (A & B) = 12, जो 0000 1100 है
| बाइनरी या ऑपरेटर थोड़ा सा कॉपी करता है अगर यह किसी भी ऑपरेंड में मौजूद है। (ए | बी) = 61, जो 0011 1101 है
^ बाइनरी एक्सओआर ऑपरेटर बिट को कॉपी करता है यदि यह एक ऑपरेंड में सेट होता है लेकिन दोनों नहीं। (ए ^ बी) = 49, जो 0011 0001 है
~ बाइनरी ओन्स कंप्लीट ऑपरेटर, एकात्मक है और इसमें 'फ्लिपिंग' बिट्स का प्रभाव होता है। (~ ए) = -61, जो हस्ताक्षरित बाइनरी नंबर के कारण 2 के पूरक में 1100 0011 है।
<< बाइनरी लेफ्ट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से छोड़ दिया जाता है। ए << 2 = 240, जो 1111 0000 है
>> बाइनरी राइट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से दाएं स्थानांतरित किया जाता है। ए >> 2 = 15, जो 0000 1111 है

असाइनमेंट ऑपरेटर्स

C # द्वारा समर्थित असाइनमेंट ऑपरेटर निम्नलिखित हैं -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
= सरल असाइनमेंट ऑपरेटर, राइट साइड ऑपरेंड्स से लेफ्ट साइड ऑपरेंड तक वैल्यू असाइन करता है C = A + B C में A + B का मान प्रदान करता है
+ = जोड़ें और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेटर के लिए सही ऑपरेंड जोड़ता है और परिणाम को बाएं ऑपरेंड में असाइन करता है C + = A C = C + A के बराबर है
- = घटाव और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेटर से दाएं ऑपरेंड को घटाता है और बाएं ऑपरेंड को परिणाम असाइन करता है C - = A C = C - A के बराबर है
* = गुणा और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेटर के साथ दाएं ऑपरेंड को गुणा करता है और परिणाम को बाएं ऑपरेंड में असाइन करता है C * = A C = C * A के बराबर है
/ = डिवाइड और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेंड को सही ऑपरेंड के साथ विभाजित करता है और परिणाम को बाएं ऑपरेंड को असाइन करता है C / = A C = C / A के बराबर है
% = मापांक और असाइनमेंट ऑपरेटर, यह दो ऑपरेंड का उपयोग करके मापांक लेता है और परिणाम को बाएं ऑपरेंड में असाइन करता है C% = A C = C% A के बराबर है
<< = Left shift AND assignment operator C <<= 2 is same as C = C << 2
>>= Right shift AND assignment operator C >>= 2 is same as C = C >> 2
&= Bitwise AND assignment operator C &= 2 is same as C = C & 2
^= bitwise exclusive OR and assignment operator C ^= 2 is same as C = C ^ 2
|= bitwise inclusive OR and assignment operator C |= 2 is same as C = C | 2

Miscellaneous Operators

There are few other important operators including sizeof, typeof and ? : supported by C#.

Show Examples

Operator Description Example
sizeof() Returns the size of a data type. sizeof(int), returns 4.
typeof() Returns the type of a class. typeof(StreamReader);
& Returns the address of an variable. &a; returns actual address of the variable.
* Pointer to a variable. *a; creates pointer named 'a' to a variable.
? : Conditional Expression If Condition is true ? Then value X : Otherwise value Y
is Determines whether an object is of a certain type. If( Ford is Car) // checks if Ford is an object of the Car class.
as Cast without raising an exception if the cast fails. Object obj = new StringReader("Hello");

StringReader r = obj as StringReader;

Operator Precedence in C#

Operator precedence determines the grouping of terms in an expression. This affects evaluation of an expression. Certain operators have higher precedence than others; for example, the multiplication operator has higher precedence than the addition operator.

For example x = 7 + 3 * 2; here, x is assigned 13, not 20 because operator * has higher precedence than +, so the first evaluation takes place for 3*2 and then 7 is added into it.

Here, operators with the highest precedence appear at the top of the table, those with the lowest appear at the bottom. Within an expression, higher precedence operators are evaluated first.

Show Examples

Category Operator Associativity
Postfix () [] -> . ++ - - Left to right
Unary + - ! ~ ++ - - (type)* & sizeof Right to left
Multiplicative * / % Left to right
Additive + - Left to right
Shift << >> Left to right
Relational < <= > >= Left to right
Equality == != Left to right
Bitwise AND & Left to right
Bitwise XOR ^ Left to right
Bitwise OR | Left to right
Logical AND && Left to right
Logical OR || Left to right
Conditional ?: Right to left
Assignment = += -= *= /= %=>>= <<= &= ^= |= Right to left
Comma , Left to right

Decision making structures requires the programmer to specify one or more conditions to be evaluated or tested by the program, along with a statement or statements to be executed if the condition is determined to be true, and optionally, other statements to be executed if the condition is determined to be false.

Following is the general form of a typical decision making structure found in most of the programming languages −

C# provides following types of decision making statements. Click the following links to check their detail.

Sr.No. Statement & Description
1 if statement

An if statement consists of a boolean expression followed by one or more statements.

2 if...else statement

An if statement can be followed by an optional else statement, which executes when the boolean expression is false.

3 nested if statements

You can use one if or else if statement inside another if or else if statement(s).

4 switch statement

A switch statement allows a variable to be tested for equality against a list of values.

5 nested switch statements

You can use one switch statement inside another switch statement(s).

The ? : Operator

We have covered conditional operator ? : in previous chapter which can be used to replace if...else statements. It has the following general form −

Exp1 ? Exp2 : Exp3;

Where Exp1, Exp2, and Exp3 are expressions. Notice the use and placement of the colon.

The value of a ? expression is determined as follows: Exp1 is evaluated. If it is true, then Exp2 is evaluated and becomes the value of the entire ? expression. If Exp1 is false, then Exp3 is evaluated and its value becomes the value of the expression.

There may be a situation, when you need to execute a block of code several number of times. In general, the statements are executed sequentially: The first statement in a function is executed first, followed by the second, and so on.

Programming languages provide various control structures that allow for more complicated execution paths.

A loop statement allows us to execute a statement or a group of statements multiple times and following is the general from of a loop statement in most of the programming languages −

C# provides following types of loop to handle looping requirements. Click the following links to check their detail.

Sr.No. Loop Type & Description
1 while loop

It repeats a statement or a group of statements while a given condition is true. It tests the condition before executing the loop body.

2 for loop

It executes a sequence of statements multiple times and abbreviates the code that manages the loop variable.

3 do...while loop

It is similar to a while statement, except that it tests the condition at the end of the loop body

4 nested loops

You can use one or more loop inside any another while, for or do..while loop.

Loop Control Statements

Loop control statements change execution from its normal sequence. When execution leaves a scope, all automatic objects that were created in that scope are destroyed.

C# provides the following control statements. Click the following links to check their details.

Sr.No. Control Statement & Description
1 break statement

Terminates the loop or switch statement and transfers execution to the statement immediately following the loop or switch.

2 continue statement

Causes the loop to skip the remainder of its body and immediately retest its condition prior to reiterating.

Infinite Loop

A loop becomes infinite loop if a condition never becomes false. The for loop is traditionally used for this purpose. Since none of the three expressions that form the for loop are required, you can make an endless loop by leaving the conditional expression empty.

Example

using System;

namespace Loops {

   class Program {
   
      static void Main(string[] args) {
         for (; ; ) {
            Console.WriteLine("Hey! I am Trapped");
         }
      }
   }
}

When the conditional expression is absent, it is assumed to be true. You may have an initialization and increment expression, but programmers more commonly use the for(;;) construct to signify an infinite loop.

Encapsulation'एक भौतिक या तार्किक पैकेज के भीतर एक या एक से अधिक आइटम संलग्न करने की प्रक्रिया' के रूप में परिभाषित किया गया है। एनकैप्सुलेशन, ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग कार्यप्रणाली में, कार्यान्वयन विवरण तक पहुंच को रोकता है।

एब्स्ट्रक्शन और एनकैप्सुलेशन ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग में संबंधित विशेषताएं हैं। अमूर्तता प्रासंगिक जानकारी को दृश्यमान बनाने की अनुमति देता है और इनकैप्सुलेशन प्रोग्रामर को अमूर्तता के वांछित स्तर को लागू करने में सक्षम बनाता है ।

एनकैप्सुलेशन का उपयोग करके कार्यान्वित किया जाता है access specifiers। एकaccess specifierएक वर्ग के सदस्य के दायरे और दृश्यता को परिभाषित करता है। C # निम्नलिखित पहुँच निर्दिष्टकों का समर्थन करता है -

  • Public
  • Private
  • Protected
  • Internal
  • संरक्षित आंतरिक

सार्वजनिक पहुँच विनिर्देशक

सार्वजनिक पहुंच निर्दिष्ट करने वाला एक वर्ग अपने सदस्य चर और सदस्य कार्यों को अन्य कार्यों और वस्तुओं को उजागर करने की अनुमति देता है। किसी भी सार्वजनिक सदस्य को वर्ग के बाहर से पहुँचा जा सकता है।

निम्न उदाहरण यह दिखाता है -

using System;

namespace RectangleApplication {

   class Rectangle {
      //member variables
      public double length;
      public double width;
      
      public double GetArea() {
         return length * width;
      }
      
      public void Display() {
         Console.WriteLine("Length: {0}", length);
         Console.WriteLine("Width: {0}", width);
         Console.WriteLine("Area: {0}", GetArea());
      }
   }//end class Rectangle
   
   class ExecuteRectangle {
      static void Main(string[] args) {
         Rectangle r = new Rectangle();
         r.length = 4.5;
         r.width = 3.5;
         r.Display();
         Console.ReadLine();
      }
   }
}

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

Length: 4.5
Width: 3.5
Area: 15.75

पूर्ववर्ती उदाहरण में, सदस्य चर लंबाई और चौड़ाई घोषित किए जाते हैं public, इसलिए उन्हें आयत वर्ग के एक उदाहरण का उपयोग करके फ़ंक्शन मेन () से एक्सेस किया जा सकता है, जिसका नाम है r

सदस्य फ़ंक्शन प्रदर्शन ( और GetArea) भी वर्ग के किसी भी उदाहरण का उपयोग किए बिना सीधे इन चर का उपयोग कर सकते हैं।

सदस्य कार्य प्रदर्शन () भी घोषित किया जाता हैpublic, इसलिए इसे आयत वर्ग के उदाहरण का उपयोग करके मेन () से भी एक्सेस किया जा सकता हैr

निजी अभिगम विनिर्देशक

निजी पहुंच विनिर्देशक वर्ग को अपने सदस्य चर और सदस्य कार्यों को अन्य कार्यों और वस्तुओं से छिपाने की अनुमति देता है। केवल उसी वर्ग के कार्य उसके निजी सदस्यों तक पहुँच सकते हैं। यहां तक ​​कि एक वर्ग का उदाहरण अपने निजी सदस्यों तक नहीं पहुंच सकता है।

निम्न उदाहरण यह दिखाता है -

using System;

namespace RectangleApplication {

   class Rectangle {
      //member variables
      private double length;
      private double width;
      
      public void Acceptdetails() {
         Console.WriteLine("Enter Length: ");
         length = Convert.ToDouble(Console.ReadLine());
         Console.WriteLine("Enter Width: ");
         width = Convert.ToDouble(Console.ReadLine());
      }
      
      public double GetArea() {
         return length * width;
      }
      
      public void Display() {
         Console.WriteLine("Length: {0}", length);
         Console.WriteLine("Width: {0}", width);
         Console.WriteLine("Area: {0}", GetArea());
      }
   }//end class Rectangle
   
   class ExecuteRectangle {
      static void Main(string[] args) {
         Rectangle r = new Rectangle();
         r.Acceptdetails();
         r.Display();
         Console.ReadLine();
      }
   }
}

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

Enter Length:
4.4
Enter Width:
3.3
Length: 4.4
Width: 3.3
Area: 14.52

पूर्ववर्ती उदाहरण में, सदस्य चर लंबाई और चौड़ाई घोषित किए जाते हैं private, इसलिए उन्हें फ़ंक्शन मेन () से एक्सेस नहीं किया जा सकता है। सदस्य फ़ंक्शन स्वीकार करता है () और प्रदर्शन () इन चर का उपयोग कर सकते हैं। चूंकि सदस्य कार्य स्वीकार करते हैं (स्वीकार) और प्रदर्शन () घोषित किए जाते हैंpublic, वे आयत वर्ग के एक उदाहरण का उपयोग करके मुख्य () से एक्सेस किए जा सकते हैं , जिसका नाम हैr

संरक्षित अभिगम विनिर्देशक

संरक्षित पहुंच विनिर्देशक एक बच्चे को अपने बेस क्लास के सदस्य चर और सदस्य कार्यों तक पहुंचने की अनुमति देता है। इस तरह यह विरासत को लागू करने में मदद करता है। हम विरासत अध्याय में अधिक विवरण में इस पर चर्चा करेंगे।

आंतरिक पहुँच विनिर्देशक

आंतरिक पहुंच विनिर्देशक एक वर्ग को वर्तमान विधानसभा में अन्य कार्यों और वस्तुओं के लिए अपने सदस्य चर और सदस्य कार्यों को उजागर करने की अनुमति देता है। दूसरे शब्दों में, आंतरिक पहुंच निर्दिष्ट करने वाला कोई भी सदस्य आवेदन के भीतर परिभाषित किसी भी वर्ग या विधि से पहुंच सकता है जिसमें सदस्य परिभाषित किया गया है।

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

using System;

namespace RectangleApplication {

   class Rectangle {
      //member variables
      internal double length;
      internal double width;
      
      double GetArea() {
         return length * width;
      }
      
      public void Display() {
         Console.WriteLine("Length: {0}", length);
         Console.WriteLine("Width: {0}", width);
         Console.WriteLine("Area: {0}", GetArea());
      }
   }//end class Rectangle
   
   class ExecuteRectangle {
      static void Main(string[] args) {
         Rectangle r = new Rectangle();
         r.length = 4.5;
         r.width = 3.5;
         r.Display();
         Console.ReadLine();
      }
   }
}

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

Length: 4.5
Width: 3.5
Area: 15.75

पूर्ववर्ती उदाहरण में, ध्यान दें कि सदस्य फ़ंक्शन GetArea () किसी भी एक्सेस स्पेसियर के साथ घोषित नहीं किया गया है। यदि हम किसी का उल्लेख नहीं करते हैं तो फिर वर्ग के सदस्य की डिफ़ॉल्ट पहुंच क्या होगी? यह हैprivate

संरक्षित आंतरिक अभिगम विनिर्देशक

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

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

एक विधि का उपयोग करने के लिए, आपको निम्न करने की आवश्यकता है -

  • विधि को परिभाषित करें
  • विधि को बुलाओ

सी # में परिभाषित करने के तरीके

जब आप किसी विधि को परिभाषित करते हैं, तो आप मूल रूप से इसकी संरचना के तत्वों की घोषणा करते हैं। C # में किसी विधि को परिभाषित करने का सिंटैक्स इस प्रकार है -

<Access Specifier> <Return Type> <Method Name>(Parameter List) {
   Method Body
}

एक विधि के विभिन्न तत्व निम्नलिखित हैं -

  • Access Specifier - यह एक चर या दूसरे वर्ग से एक विधि की दृश्यता निर्धारित करता है।

  • Return type- कोई विधि मान वापस कर सकती है। रिटर्न प्रकार विधि रिटर्न के मूल्य का डेटा प्रकार है। यदि विधि कोई मान नहीं लौटा रही है, तो वापसी प्रकार हैvoid

  • Method name- विधि का नाम एक विशिष्ट पहचानकर्ता है और यह संवेदनशील है। यह कक्षा में घोषित किसी अन्य पहचानकर्ता के समान नहीं हो सकता है।

  • Parameter list- कोष्ठक के बीच संलग्न, एक विधि से डेटा पास और प्राप्त करने के लिए मापदंडों का उपयोग किया जाता है। पैरामीटर सूची एक विधि के मापदंडों के प्रकार, आदेश और संख्या को संदर्भित करती है। पैरामीटर वैकल्पिक हैं; अर्थात्, एक विधि में कोई पैरामीटर नहीं हो सकता है।

  • Method body - इसमें आवश्यक गतिविधि को पूरा करने के लिए आवश्यक निर्देशों का समूह शामिल है।

उदाहरण

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

class NumberManipulator {

   public int FindMax(int num1, int num2) {
      /* local variable declaration */
      int result;

      if (num1 > num2)
         result = num1;
      else
         result = num2;

      return result;
   }
   ...
}

C # में कॉलिंग मेथड

आप विधि के नाम का उपयोग करके एक विधि कह सकते हैं। निम्न उदाहरण यह दिखाता है -

using System;

namespace CalculatorApplication {

   class NumberManipulator {
   
      public int FindMax(int num1, int num2) {
         /* local variable declaration */
         int result;
         
         if (num1 > num2)
            result = num1;
         else
            result = num2;
         return result;
      }
      
      static void Main(string[] args) {
         /* local variable definition */
         int a = 100;
         int b = 200;
         int ret;
         NumberManipulator n = new NumberManipulator();

         //calling the FindMax method
         ret = n.FindMax(a, b);
         Console.WriteLine("Max value is : {0}", ret );
         Console.ReadLine();
      }
   }
}

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

Max value is : 200

आप कक्षा के उदाहरण का उपयोग करके अन्य कक्षाओं से भी सार्वजनिक विधि को कॉल कर सकते हैं। उदाहरण के लिए, विधि FindMax के अंतर्गत आता है NumberManipulator वर्ग, आप इसे किसी अन्य वर्ग से कॉल कर सकते हैं टेस्ट

using System;

namespace CalculatorApplication {

   class NumberManipulator {
   
      public int FindMax(int num1, int num2) {
         /* local variable declaration */
         int result;
         
         if(num1 > num2)
            result = num1;
         else
            result = num2;
         
         return result;
      }
   }
   
   class Test {
   
      static void Main(string[] args) {
         /* local variable definition */
         int a = 100;
         int b = 200;
         int ret;
         NumberManipulator n = new NumberManipulator();
         
         //calling the FindMax method
         ret = n.FindMax(a, b);
         Console.WriteLine("Max value is : {0}", ret );
         Console.ReadLine();
      }
   }
}

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

Max value is : 200

पुनरावर्ती विधि कॉल

एक विधि स्वयं कह सकती है। इस रूप में जाना जाता हैrecursion। निम्नलिखित एक उदाहरण है जो किसी पुनरावर्ती फ़ंक्शन का उपयोग करके दिए गए संख्या के लिए भाज्य की गणना करता है -

using System;

namespace CalculatorApplication {

   class NumberManipulator {
   
      public int factorial(int num) {
         /* local variable declaration */
         int result;
         if (num == 1) {
            return 1;
         }
         else {
            result = factorial(num - 1) * num;
            return result;
         }
      }
      
      static void Main(string[] args) {
         NumberManipulator n = new NumberManipulator();
         //calling the factorial method {0}", n.factorial(6));
         Console.WriteLine("Factorial of 7 is : {0}", n.factorial(7));
         Console.WriteLine("Factorial of 8 is : {0}", n.factorial(8));
         Console.ReadLine();
      }
   }
}

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

Factorial of 6 is: 720
Factorial of 7 is: 5040
Factorial of 8 is: 40320

एक विधि के लिए पैरामीटर पारित करना

जब मापदंडों के साथ विधि कहा जाता है, तो आपको विधि को मापदंडों को पास करना होगा। तीन तरीके हैं जो पैरामीटर को एक विधि में पारित किया जा सकता है -

अनु क्रमांक। तंत्र और विवरण
1 मान पैरामीटर

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

2 संदर्भ पैरामीटर

यह विधि एक तर्क की स्मृति स्थान के संदर्भ को औपचारिक पैरामीटर में कॉपी करती है। इसका अर्थ है कि पैरामीटर में किए गए परिवर्तन तर्क को प्रभावित करते हैं।

3 आउटपुट पैरामीटर

यह विधि एक से अधिक मूल्य वापस करने में मदद करती है।

C # एक विशेष डेटा प्रकार प्रदान करता है, nullable प्रकार, जिनमें से आप सामान्य मानों के साथ-साथ अशक्त मान निर्दिष्ट कर सकते हैं।

उदाहरण के लिए, आप किसी भी मूल्य को -2,147,483,648 से 2,147,483,647 या अशक्त <Int32> चर में नल कर सकते हैं। इसी तरह, आप Nullable <bool> वेरिएबल में सही, गलत या अशक्त असाइन कर सकते हैं। एक की घोषणा के लिए सिंटैक्सnullable प्रकार इस प्रकार है -

< data_type> ? <variable_name> = null;

निम्न उदाहरण अशक्त डेटा प्रकारों के उपयोग को प्रदर्शित करता है -

using System;

namespace CalculatorApplication {

   class NullablesAtShow {
   
      static void Main(string[] args) {
         int? num1 = null;
         int? num2 = 45;
         double? num3 = new double?();
         double? num4 = 3.14157;
         
         bool? boolval = new bool?();

         // display the values
         Console.WriteLine("Nullables at Show: {0}, {1}, {2}, {3}", num1, num2, num3, num4);
         Console.WriteLine("A Nullable boolean value: {0}", boolval);
         Console.ReadLine();
      }
   }
}

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

Nullables at Show: , 45,  , 3.14157
A Nullable boolean value:

अशक्त संचालक संचालक (??)

नल coalescing ऑपरेटर nullable मूल्य प्रकार और संदर्भ प्रकार के साथ प्रयोग किया जाता है। इसका उपयोग एक ऑपरेंड को दूसरे अशक्त (या नहीं) मूल्य प्रकार के ऑपरेंड में बदलने के लिए किया जाता है, जहां एक अंतर्निहित रूपांतरण संभव है।

यदि पहले ऑपरेंड का मान शून्य है, तो ऑपरेटर दूसरे ऑपरेंड का मान लौटाता है, अन्यथा यह पहले ऑपरेंड का मूल्य लौटाता है। निम्नलिखित उदाहरण यह बताते हैं -

using System;

namespace CalculatorApplication {

   class NullablesAtShow {
   
      static void Main(string[] args) {
         double? num1 = null;
         double? num2 = 3.14157;
         double num3;
         num3 = num1 ?? 5.34;      
         Console.WriteLine(" Value of num3: {0}", num3);
         num3 = num2 ?? 5.34;
         Console.WriteLine(" Value of num3: {0}", num3);
         Console.ReadLine();
      }
   }
}

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

Value of num3: 5.34
Value of num3: 3.14157

एक सरणी उसी प्रकार के तत्वों के एक निश्चित आकार के अनुक्रमिक संग्रह को संग्रहीत करता है। एक सरणी का उपयोग डेटा के संग्रह को संग्रहित करने के लिए किया जाता है, लेकिन यह अक्सर एक सरणी के बारे में सोचने के लिए अधिक उपयोगी होता है क्योंकि एक ही प्रकार के चर के संग्रह को सन्निहित स्मृति स्थानों पर संग्रहीत किया जाता है।

नंबर चर, नंबर 1, ... और नंबर 99 जैसे अलग-अलग चर घोषित करने के बजाय, आप एक सरणी चर जैसे संख्याओं की घोषणा करते हैं और संख्याओं का उपयोग करते हैं [0], संख्याओं [1] और ..., संख्याओं [99] का प्रतिनिधित्व करने के लिए। अलग-अलग चर। एक सरणी में एक विशिष्ट तत्व एक सूचकांक द्वारा पहुँचा जाता है।

सभी सरणियों में सन्निहित स्मृति स्थान शामिल हैं। निम्नतम पता पहले तत्व से मेल खाता है और उच्चतम पता अंतिम तत्व से।

घोषणाएँ

C # में एक सरणी घोषित करने के लिए, आप निम्न सिंटैक्स का उपयोग कर सकते हैं -

datatype[] arrayName;

कहाँ पे,

  • सरणी में तत्वों के प्रकार को निर्दिष्ट करने के लिए डेटाटाइप का उपयोग किया जाता है।

  • [] सरणी की रैंक निर्दिष्ट करता है। रैंक सरणी का आकार निर्दिष्ट करता है।

  • arrayName सरणी का नाम निर्दिष्ट करता है।

उदाहरण के लिए,

double[] balance;

एक ऐरे को शुरू करना

सरणी घोषित करना स्मृति में सरणी को प्रारंभ नहीं करता है। जब ऐरे वेरिएबल को इनिशियलाइज़ किया जाता है, तो आप ऐरे को मान असाइन कर सकते हैं।

सरणी एक संदर्भ प्रकार है, इसलिए आपको इसका उपयोग करने की आवश्यकता है newसरणी का एक उदाहरण बनाने के लिए कीवर्ड। उदाहरण के लिए,

double[] balance = new double[10];

मान को एक सरणी में सौंपना

आप इंडेक्स नंबर का उपयोग करके व्यक्तिगत सरणी तत्वों को मान प्रदान कर सकते हैं, जैसे -

double[] balance = new double[10];
balance[0] = 4500.0;

आप घोषणा के समय सरणी में मान असाइन कर सकते हैं, जैसा कि दिखाया गया है -

double[] balance = { 2340.0, 4523.69, 3421.0};

जैसा कि दिखाया गया है, आप एक सरणी भी बना सकते हैं और आरंभ कर सकते हैं -

int [] marks = new int[5]  { 99,  98, 92, 97, 95};

जैसा कि दिखाया गया है, आप सरणी के आकार को छोड़ सकते हैं -

int [] marks = new int[]  { 99,  98, 92, 97, 95};

आप एक सरणी चर को दूसरे लक्ष्य सरणी चर में कॉपी कर सकते हैं। ऐसे मामले में, लक्ष्य और स्रोत दोनों एक ही मेमोरी लोकेशन की ओर इशारा करते हैं -

int [] marks = new int[]  { 99,  98, 92, 97, 95};
int[] score = marks;

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

ऐरे तत्वों तक पहुँचना

सरणी नाम को अनुक्रमित करके एक तत्व को एक्सेस किया जाता है। यह सरणी के नाम के बाद वर्ग ब्रैकेट के भीतर तत्व के सूचकांक को रखकर किया जाता है। उदाहरण के लिए,

double salary = balance[9];

निम्नलिखित उदाहरण, उपर्युक्त अवधारणाओं की घोषणा, असाइनमेंट, और एक्सेस करने वाले सरणियों को प्रदर्शित करता है -

using System;

namespace ArrayApplication {

   class MyArray {
   
      static void Main(string[] args) {
         int []  n = new int[10]; /* n is an array of 10 integers */
         int i,j;

         /* initialize elements of array n */
         for ( i = 0; i < 10; i++ ) {
            n[ i ] = i + 100;
         }
         
         /* output each array element's value */
         for (j = 0; j < 10; j++ ) {
            Console.WriteLine("Element[{0}] = {1}", j, n[j]);
         }
         Console.ReadKey();
      }
   }
}

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

Element[0] = 100
Element[1] = 101
Element[2] = 102
Element[3] = 103
Element[4] = 104
Element[5] = 105
Element[6] = 106
Element[7] = 107
Element[8] = 108
Element[9] = 109

फॉर्च लूप का उपयोग करना

पिछले उदाहरण में, हमने प्रत्येक सरणी तत्व तक पहुंचने के लिए लूप के लिए उपयोग किया। तुम भी एक का उपयोग कर सकते हैंforeach एक सरणी के माध्यम से पुनरावृति करने के लिए बयान।

using System;

namespace ArrayApplication {

   class MyArray {
   
      static void Main(string[] args) {
         int []  n = new int[10]; /* n is an array of 10 integers */
         
         /* initialize elements of array n */
         for ( int i = 0; i < 10; i++ ) {
            n[i] = i + 100;
         }
         
         /* output each array element's value */
         foreach (int j in n ) {
            int i = j-100;
            Console.WriteLine("Element[{0}] = {1}", i, j);
            
         }
         Console.ReadKey();
      }
   }
}

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

Element[0] = 100
Element[1] = 101
Element[2] = 102
Element[3] = 103
Element[4] = 104
Element[5] = 105
Element[6] = 106
Element[7] = 107
Element[8] = 108
Element[9] = 109

C # एरेस

सरणी से संबंधित कुछ महत्वपूर्ण अवधारणाएँ निम्नलिखित हैं, जो C # प्रोग्रामर के लिए स्पष्ट होनी चाहिए -

अनु क्रमांक। अवधारणा और विवरण
1 बहुआयामी सरणियाँ

C # बहुआयामी सरणियों का समर्थन करता है। बहुआयामी सरणी का सबसे सरल रूप द्वि-आयामी सरणी है।

2 दांतेदार गिरफ्तारी

C # बहुआयामी सरणियों का समर्थन करता है, जो सरणियों के सारणी हैं।

3 कार्यों के लिए सरणियाँ पासिंग

आप एक इंडेक्स के बिना सरणी के नाम को निर्दिष्ट करके एक सरणी के लिए फ़ंक्शन को एक पॉइंटर पास कर सकते हैं।

4 परम को गिरफ्तार किया

इसका उपयोग किसी फ़ंक्शन में अज्ञात संख्याओं को पारित करने के लिए किया जाता है।

5 द अर्रे क्लास

सिस्टम नेमस्पेस में परिभाषित, यह सभी सरणियों का आधार वर्ग है, और सरणियों के साथ काम करने के लिए विभिन्न गुण और तरीके प्रदान करता है।

C # में, आप वर्णों के सरणी के रूप में स्ट्रिंग्स का उपयोग कर सकते हैं, हालाँकि, अधिक सामान्य अभ्यास का उपयोग करना है stringएक स्ट्रिंग चर घोषित करने के लिए कीवर्ड। स्ट्रिंग कीवर्ड के लिए एक उपनाम हैSystem.String कक्षा।

एक स्ट्रिंग ऑब्जेक्ट बनाना

आप निम्न विधियों में से किसी एक का उपयोग करके स्ट्रिंग ऑब्जेक्ट बना सकते हैं -

  • स्ट्रिंग स्ट्रिंग को एक स्ट्रिंग वेरिएबल असाइन करके

  • एक स्ट्रिंग क्लास कंस्ट्रक्टर का उपयोग करके

  • स्ट्रिंग संघनन ऑपरेटर (+) का उपयोग करके

  • किसी संपत्ति को प्राप्त करने या एक विधि को कॉल करके जो एक स्ट्रिंग लौटाता है

  • किसी मान या ऑब्जेक्ट को उसके स्ट्रिंग प्रतिनिधित्व में बदलने के लिए एक प्रारूपण विधि को कॉल करके

निम्न उदाहरण यह प्रदर्शित करता है -

using System;

namespace StringApplication {

   class Program {
   
      static void Main(string[] args) {
         //from string literal and string concatenation
         string fname, lname;
         fname = "Rowan";
         lname = "Atkinson";
			
         char []letters= { 'H', 'e', 'l', 'l','o' };
         string [] sarray={ "Hello", "From", "Tutorials", "Point" };
			
         string fullname = fname + lname;
         Console.WriteLine("Full Name: {0}", fullname);
         
         //by using string constructor { 'H', 'e', 'l', 'l','o' };
         string greetings = new string(letters);
         Console.WriteLine("Greetings: {0}", greetings);
         
         //methods returning string { "Hello", "From", "Tutorials", "Point" };
         string message = String.Join(" ", sarray);
         Console.WriteLine("Message: {0}", message);
         
         //formatting method to convert a value
         DateTime waiting = new DateTime(2012, 10, 10, 17, 58, 1);
         string chat = String.Format("Message sent at {0:t} on {0:D}", waiting);
         Console.WriteLine("Message: {0}", chat);
      }
   }
}

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

Full Name: RowanAtkinson
Greetings: Hello
Message: Hello From Tutorials Point
Message: Message sent at 5:58 PM on Wednesday, October 10, 2012

स्ट्रिंग क्लास के गुण

स्ट्रिंग वर्ग में निम्नलिखित दो गुण हैं -

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

Chars

हो जाता है चार वर्तमान में एक निर्दिष्ट स्थान पर वस्तु स्ट्रिंग वस्तु।

2

Length

वर्तमान स्ट्रिंग ऑब्जेक्ट में वर्णों की संख्या प्राप्त करता है।

स्ट्रिंग क्लास के तरीके

स्ट्रिंग क्लास में कई तरीके हैं जो आपको स्ट्रिंग ऑब्जेक्ट्स के साथ काम करने में मदद करते हैं। निम्न तालिका सबसे अधिक इस्तेमाल की जाने वाली विधियों में से कुछ प्रदान करती है -

अनु क्रमांक। तरीके और विवरण
1

public static int Compare(string strA, string strB)

दो निर्दिष्ट स्ट्रिंग ऑब्जेक्ट्स की तुलना करता है और एक पूर्णांक देता है जो सॉर्ट क्रम में उनकी सापेक्ष स्थिति को इंगित करता है।

2

public static int Compare(string strA, string strB, bool ignoreCase )

दो निर्दिष्ट स्ट्रिंग ऑब्जेक्ट्स की तुलना करता है और एक पूर्णांक देता है जो सॉर्ट क्रम में उनकी सापेक्ष स्थिति को इंगित करता है। हालाँकि, यह मामले की अनदेखी करता है यदि बूलियन पैरामीटर सत्य है।

3

public static string Concat(string str0, string str1)

दो स्ट्रिंग ऑब्जेक्ट्स को समेटता है।

4

public static string Concat(string str0, string str1, string str2)

तीन स्ट्रिंग ऑब्जेक्ट को समेटता है।

5

public static string Concat(string str0, string str1, string str2, string str3)

चार स्ट्रिंग ऑब्जेक्ट को समेटता है।

6

public bool Contains(string value)

इस स्ट्रिंग के भीतर निर्दिष्ट स्ट्रिंग ऑब्जेक्ट होता है या नहीं, यह दर्शाता है कि एक मान लौटाता है।

7

public static string Copy(string str)

निर्दिष्ट स्ट्रिंग के समान मान के साथ एक नया स्ट्रिंग ऑब्जेक्ट बनाता है।

8

public void CopyTo(int sourceIndex, char[] destination, int destinationIndex, int count)

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

9

public bool EndsWith(string value)

निर्धारित करता है कि स्ट्रिंग ऑब्जेक्ट का अंत निर्दिष्ट स्ट्रिंग से मेल खाता है या नहीं।

10

public bool Equals(string value)

निर्धारित करता है कि क्या वर्तमान स्ट्रिंग ऑब्जेक्ट और निर्दिष्ट स्ट्रिंग ऑब्जेक्ट का एक ही मूल्य है।

1 1

public static bool Equals(string a, string b)

निर्धारित करता है कि दो निर्दिष्ट स्ट्रिंग वस्तुओं का एक ही मूल्य है।

12

public static string Format(string format, Object arg0)

एक निर्दिष्ट ऑब्जेक्ट के स्ट्रिंग प्रतिनिधित्व के साथ एक निर्दिष्ट स्ट्रिंग में एक या एक से अधिक प्रारूप आइटम प्रतिस्थापित करता है।

13

public int IndexOf(char value)

वर्तमान स्ट्रिंग में निर्दिष्ट यूनिकोड वर्ण की पहली घटना के शून्य-आधारित सूचकांक को लौटाता है।

14

public int IndexOf(string value)

इस उदाहरण में निर्दिष्ट स्ट्रिंग की पहली घटना के शून्य-आधारित सूचकांक को लौटाता है।

15

public int IndexOf(char value, int startIndex)

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

16

public int IndexOf(string value, int startIndex)

निर्दिष्ट उदाहरण स्थिति में खोज शुरू करते हुए, इस उदाहरण में निर्दिष्ट स्ट्रिंग की पहली घटना के शून्य-आधारित सूचकांक को लौटाता है।

17

public int IndexOfAny(char[] anyOf)

यूनिकोड वर्णों के एक निर्दिष्ट सरणी में किसी भी वर्ण के इस उदाहरण में पहली घटना के शून्य-आधारित सूचकांक को लौटाता है।

18

public int IndexOfAny(char[] anyOf, int startIndex)

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

19

public string Insert(int startIndex, string value)

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

20

public static bool IsNullOrEmpty(string value)

इंगित करता है कि निर्दिष्ट स्ट्रिंग शून्य है या एक रिक्त स्ट्रिंग है।

21

public static string Join(string separator, params string[] value)

प्रत्येक तत्व के बीच निर्दिष्ट विभाजक का उपयोग करते हुए, एक स्ट्रिंग सरणी के सभी तत्वों को सम्मिलित करता है।

22

public static string Join(string separator, string[] value, int startIndex, int count)

प्रत्येक तत्व के बीच निर्दिष्ट विभाजक का उपयोग करके, एक स्ट्रिंग सरणी के निर्दिष्ट तत्वों को सम्‍मिलित करता है।

23

public int LastIndexOf(char value)

वर्तमान स्ट्रिंग ऑब्जेक्ट के भीतर निर्दिष्ट यूनिकोड वर्ण की अंतिम घटना के शून्य-आधारित सूचकांक स्थिति को लौटाता है।

24

public int LastIndexOf(string value)

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

25

public string Remove(int startIndex)

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

26

public string Remove(int startIndex, int count)

वर्तमान स्ट्रिंग शुरुआत में निर्दिष्ट स्थान पर वर्णों की निर्दिष्ट संख्या निकालता है और स्ट्रिंग लौटाता है।

27

public string Replace(char oldChar, char newChar)

वर्तमान स्ट्रिंग ऑब्जेक्ट में निर्दिष्ट यूनिकोड वर्ण की सभी घटनाओं को निर्दिष्ट यूनिकोड वर्ण के साथ बदल देता है और नया स्ट्रिंग लौटाता है।

28

public string Replace(string oldValue, string newValue)

वर्तमान स्ट्रिंग ऑब्जेक्ट में निर्दिष्ट स्ट्रिंग के साथ निर्दिष्ट स्ट्रिंग के सभी आवृत्तियों को प्रतिस्थापित करता है और नई स्ट्रिंग लौटाता है।

29

public string[] Split(params char[] separator)

एक स्ट्रिंग सरणी लौटाता है जिसमें वर्तमान स्ट्रिंग ऑब्जेक्ट में सबस्ट्रिंग होता है, एक निर्दिष्ट यूनिकोड वर्ण सरणी के तत्वों द्वारा सीमांकित।

30

public string[] Split(char[] separator, int count)

एक स्ट्रिंग सरणी लौटाता है जिसमें वर्तमान स्ट्रिंग ऑब्जेक्ट में सबस्ट्रिंग होता है, एक निर्दिष्ट यूनिकोड वर्ण सरणी के तत्वों द्वारा सीमांकित। इंट पैरामीटर पैरामीटर की अधिकतम संख्या को वापस करने के लिए निर्दिष्ट करता है।

31

public bool StartsWith(string value)

निर्धारित करता है कि इस स्ट्रिंग आवृत्ति की शुरुआत निर्दिष्ट स्ट्रिंग से मेल खाती है या नहीं।

32

public char[] ToCharArray()

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

33

public char[] ToCharArray(int startIndex, int length)

वर्तमान स्ट्रिंग ऑब्जेक्ट में सभी वर्णों के साथ एक यूनिकोड वर्ण सरणी देता है, निर्दिष्ट सूचकांक से और निर्दिष्ट लंबाई तक शुरू होता है।

34

public string ToLower()

इस स्ट्रिंग की एक प्रति लौटाकर लोअरकेस में बदल देता है।

35

public string ToUpper()

इस स्ट्रिंग की एक प्रति को अपरकेस में बदल देता है।

36

public string Trim()

वर्तमान स्ट्रिंग ऑब्जेक्ट से सभी प्रमुख और अनुगामी श्वेत-रिक्त वर्णों को निकालता है।

तरीकों और स्ट्रिंग वर्ग के निर्माणकर्ताओं की पूरी सूची के लिए आप MSDN लाइब्रेरी का दौरा कर सकते हैं।

उदाहरण

निम्नलिखित उदाहरण ऊपर वर्णित कुछ विधियों को प्रदर्शित करता है -

तुलना स्ट्रिंग्स

using System;

namespace StringApplication {

   class StringProg {
   
      static void Main(string[] args) {
         string str1 = "This is test";
         string str2 = "This is text";

         if (String.Compare(str1, str2) == 0) {
            Console.WriteLine(str1 + " and " + str2 +  " are equal.");
         } else {
            Console.WriteLine(str1 + " and " + str2 + " are not equal.");
         }
         Console.ReadKey() ;
      }
   }
}

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

This is test and This is text are not equal.

स्ट्रिंग में स्ट्रिंग शामिल है

using System;

namespace StringApplication {

   class StringProg {
   
      static void Main(string[] args) {
         string str = "This is test";
         
         if (str.Contains("test")) {
            Console.WriteLine("The sequence 'test' was found.");
         }
         Console.ReadKey() ;
      }
   }
}

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

The sequence 'test' was found.

एक पदार्थ हो रहा है

using System;

namespace StringApplication {

   class StringProg {
   
      static void Main(string[] args) {
         string str = "Last night I dreamt of San Pedro";
         Console.WriteLine(str);
         string substr = str.Substring(23);
         Console.WriteLine(substr);
      }
   }
}

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

San Pedro

तार जुड़ना

using System;

namespace StringApplication {

   class StringProg {
   
      static void Main(string[] args) {
         string[] starray = new string[]{"Down the way nights are dark",
            "And the sun shines daily on the mountain top",
            "I took a trip on a sailing ship",
            "And when I reached Jamaica",
            "I made a stop"};

         string str = String.Join("\n", starray);
         Console.WriteLine(str);
      }
   }
}

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

Down the way nights are dark
And the sun shines daily on the mountain top
I took a trip on a sailing ship
And when I reached Jamaica
I made a stop

C # में, एक संरचना मान प्रकार डेटा प्रकार है। यह आपको विभिन्न डेटा प्रकारों के एकल चर पकड़ संबंधी डेटा बनाने में मदद करता है। struct कीवर्ड का उपयोग एक संरचना बनाने के लिए किया जाता है।

एक रिकॉर्ड का प्रतिनिधित्व करने के लिए संरचनाओं का उपयोग किया जाता है। मान लीजिए कि आप किसी लाइब्रेरी में अपनी पुस्तकों पर नज़र रखना चाहते हैं। आप प्रत्येक पुस्तक के बारे में निम्नलिखित विशेषताओं को ट्रैक करना चाहते हैं -

  • Title
  • Author
  • Subject
  • बुक आईडी

एक संरचना को परिभाषित करना

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

उदाहरण के लिए, यहाँ आप पुस्तक संरचना की घोषणा कर सकते हैं -

struct Books {
   public string title;
   public string author;
   public string subject;
   public int book_id;
};

निम्नलिखित कार्यक्रम संरचना के उपयोग को दर्शाता है -

using System;

struct Books {
   public string title;
   public string author;
   public string subject;
   public int book_id;
};  

public class testStructure {

   public static void Main(string[] args) {
      Books Book1;   /* Declare Book1 of type Book */
      Books Book2;   /* Declare Book2 of type Book */

      /* book 1 specification */
      Book1.title = "C Programming";
      Book1.author = "Nuha Ali"; 
      Book1.subject = "C Programming Tutorial";
      Book1.book_id = 6495407;

      /* book 2 specification */
      Book2.title = "Telecom Billing";
      Book2.author = "Zara Ali";
      Book2.subject =  "Telecom Billing Tutorial";
      Book2.book_id = 6495700;

      /* print Book1 info */
      Console.WriteLine( "Book 1 title : {0}", Book1.title);
      Console.WriteLine("Book 1 author : {0}", Book1.author);
      Console.WriteLine("Book 1 subject : {0}", Book1.subject);
      Console.WriteLine("Book 1 book_id :{0}", Book1.book_id);

      /* print Book2 info */
      Console.WriteLine("Book 2 title : {0}", Book2.title);
      Console.WriteLine("Book 2 author : {0}", Book2.author);
      Console.WriteLine("Book 2 subject : {0}", Book2.subject);
      Console.WriteLine("Book 2 book_id : {0}", Book2.book_id);       

      Console.ReadKey();
   }
}

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

Book 1 title : C Programming
Book 1 author : Nuha Ali
Book 1 subject : C Programming Tutorial
Book 1 book_id : 6495407
Book 2 title : Telecom Billing
Book 2 author : Zara Ali
Book 2 subject : Telecom Billing Tutorial
Book 2 book_id : 6495700

सी # संरचनाओं की विशेषताएं

आपने पहले से ही बुक नामक एक सरल संरचना का उपयोग किया है। C # में संरचनाएं पारंपरिक C या C ++ से काफी भिन्न हैं। C # संरचनाओं में निम्नलिखित विशेषताएं हैं -

  • संरचनाओं में विधियाँ, फ़ील्ड्स, इंडेक्सर्स, प्रॉपर्टीज़, ऑपरेटर विधियाँ और ईवेंट हो सकते हैं।

  • संरचनाओं में परिभाषित निर्माता हो सकते हैं, लेकिन विध्वंसक नहीं। हालाँकि, आप किसी संरचना के लिए डिफ़ॉल्ट निर्माता को परिभाषित नहीं कर सकते। डिफ़ॉल्ट निर्माता स्वचालित रूप से परिभाषित है और उसे बदला नहीं जा सकता है।

  • कक्षाओं के विपरीत, संरचनाएं अन्य संरचनाओं या कक्षाओं को विरासत में नहीं ले सकती हैं।

  • अन्य संरचनाओं या वर्गों के लिए आधार के रूप में संरचनाओं का उपयोग नहीं किया जा सकता है।

  • एक संरचना एक या अधिक इंटरफेस को लागू कर सकती है।

  • संरचना सदस्यों को सार, आभासी या संरक्षित के रूप में निर्दिष्ट नहीं किया जा सकता है।

  • जब आप एक संरचनात्मक वस्तु का उपयोग करते हैं Newऑपरेटर, इसे बनाया जाता है और उपयुक्त निर्माता को बुलाया जाता है। वर्गों के विपरीत, न्यू ऑपरेटर का उपयोग किए बिना स्ट्रक्चर्स को तत्काल किया जा सकता है।

  • यदि नए ऑपरेटर का उपयोग नहीं किया जाता है, तो फ़ील्ड अप्रकाशित रहते हैं और ऑब्जेक्ट का उपयोग तब तक नहीं किया जा सकता है जब तक कि सभी फ़ील्ड प्रारंभ न हो जाएं।

वर्ग बनाम संरचना

वर्गों और संरचनाओं में निम्नलिखित बुनियादी अंतर हैं -

  • कक्षाएं संदर्भ प्रकार हैं और संरचना मूल्य प्रकार हैं
  • संरचनाएं वंशानुक्रम का समर्थन नहीं करती हैं
  • संरचनाओं में डिफ़ॉल्ट कंस्ट्रक्टर नहीं हो सकता है

उपरोक्त चर्चाओं के आलोक में, हम पिछले उदाहरण को फिर से लिखते हैं -

using System;

struct Books {
   private string title;
   private string author;
   private string subject;
   private int book_id;
   
   public void getValues(string t, string a, string s, int id) {
      title = t;
      author = a;
      subject = s;
      book_id = id;
   }
   
   public void display() {
      Console.WriteLine("Title : {0}", title);
      Console.WriteLine("Author : {0}", author);
      Console.WriteLine("Subject : {0}", subject);
      Console.WriteLine("Book_id :{0}", book_id);
   }
};  

public class testStructure {

   public static void Main(string[] args) {
      Books Book1 = new Books();   /* Declare Book1 of type Book */
      Books Book2 = new Books();   /* Declare Book2 of type Book */

      /* book 1 specification */
      Book1.getValues("C Programming",
      "Nuha Ali", "C Programming Tutorial",6495407);

      /* book 2 specification */
      Book2.getValues("Telecom Billing",
      "Zara Ali", "Telecom Billing Tutorial", 6495700);

      /* print Book1 info */
      Book1.display();

      /* print Book2 info */
      Book2.display(); 

      Console.ReadKey();
   }
}

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

Title : C Programming
Author : Nuha Ali
Subject : C Programming Tutorial
Book_id : 6495407
Title : Telecom Billing
Author : Zara Ali
Subject : Telecom Billing Tutorial
Book_id : 6495700

एक गणना नामांकित पूर्णांक स्थिरांक का एक सेट है। का उपयोग कर एक प्रगणित प्रकार घोषित किया जाता हैenum कीवर्ड।

C # एन्यूमरेशन मान डेटा प्रकार हैं। दूसरे शब्दों में, एन्यूमरेशन के अपने मूल्य होते हैं और इनहेरिट नहीं कर सकते हैं या इनहेरिटेंस पास नहीं कर सकते हैं।

घोषित करने योग्य एनम चर

एन्यूमरेशन घोषित करने का सामान्य सिंटैक्स है -

enum <enum_name> {
   enumeration list 
};

कहाँ पे,

  • Enum_name गणना प्रकार नाम निर्दिष्ट करता है।

  • गणन सूची पहचान वाली अल्पविराम से अलग सूची है।

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

enum Days { Sun, Mon, tue, Wed, thu, Fri, Sat };

उदाहरण

निम्न उदाहरण एनम चर का उपयोग दर्शाता है -

using System;

namespace EnumApplication {

   class EnumProgram {
      enum Days { Sun, Mon, tue, Wed, thu, Fri, Sat };

      static void Main(string[] args) {
         int WeekdayStart = (int)Days.Mon;
         int WeekdayEnd = (int)Days.Fri;
         Console.WriteLine("Monday: {0}", WeekdayStart);
         Console.WriteLine("Friday: {0}", WeekdayEnd);
         Console.ReadKey();
      }
   }
}

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

Monday: 1
Friday: 5

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

एक कक्षा को परिभाषित करना

एक वर्ग की परिभाषा कीवर्ड वर्ग के साथ शुरू होती है और उसके बाद कक्षा नाम; और घुंघराले ब्रेसिज़ की एक जोड़ी द्वारा संलग्न वर्ग शरीर। निम्नलिखित एक वर्ग परिभाषा का सामान्य रूप है -

<access specifier> class  class_name {
   // member variables
   <access specifier> <data type> variable1;
   <access specifier> <data type> variable2;
   ...
   <access specifier> <data type> variableN;
   // member methods
   <access specifier> <return type> method1(parameter_list) {
      // method body
   }
   <access specifier> <return type> method2(parameter_list) {
      // method body
   }
   ...
   <access specifier> <return type> methodN(parameter_list) {
      // method body
   }
}

नोट -

  • एक्सेस विनिर्देशक सदस्यों के लिए और साथ ही कक्षा के लिए पहुँच नियमों को निर्दिष्ट करते हैं। यदि उल्लेख नहीं किया गया है, तो एक वर्ग प्रकार के लिए डिफ़ॉल्ट पहुंच निर्दिष्ट हैinternal। सदस्यों के लिए डिफ़ॉल्ट पहुंच हैprivate

  • डेटा प्रकार चर के प्रकार को निर्दिष्ट करता है, और रिटर्न प्रकार डेटा के डेटा प्रकार को निर्दिष्ट करता है विधि रिटर्न, यदि कोई हो।

  • वर्ग के सदस्यों तक पहुँचने के लिए, आप डॉट (।) ऑपरेटर का उपयोग करते हैं।

  • डॉट ऑपरेटर किसी सदस्य के नाम के साथ किसी ऑब्जेक्ट का नाम जोड़ता है।

निम्नलिखित उदाहरण अब तक चर्चा की गई अवधारणाओं को दिखाता है -

using System;

namespace BoxApplication {

    class Box {
       public double length;   // Length of a box
       public double breadth;  // Breadth of a box
       public double height;   // Height of a box
    }
    
    class Boxtester {

        static void Main(string[] args) {
            Box Box1 = new Box();   // Declare Box1 of type Box
            Box Box2 = new Box();   // Declare Box2 of type Box
            double volume = 0.0;    // Store the volume of a box here

            // box 1 specification
            Box1.height = 5.0;
            Box1.length = 6.0;
            Box1.breadth = 7.0;

            // box 2 specification
            Box2.height = 10.0;
            Box2.length = 12.0;
            Box2.breadth = 13.0;
           
            // volume of box 1
            volume = Box1.height * Box1.length * Box1.breadth;
            Console.WriteLine("Volume of Box1 : {0}",  volume);

            // volume of box 2
            volume = Box2.height * Box2.length * Box2.breadth;
            Console.WriteLine("Volume of Box2 : {0}", volume);
            Console.ReadKey();
        }
    }
}

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

Volume of Box1 : 210
Volume of Box2 : 1560

सदस्य कार्य और एनकैप्सुलेशन

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

सदस्य चर किसी वस्तु की विशेषता (डिजाइन के नजरिए से) होते हैं और इनकैप्सुलेशन को लागू करने के लिए उन्हें निजी रखा जाता है। ये चर केवल सार्वजनिक सदस्य कार्यों का उपयोग करके पहुँचा जा सकता है।

आइए हम एक कक्षा में विभिन्न वर्ग के सदस्यों के मूल्य निर्धारित करने और प्राप्त करने के लिए अवधारणाओं को ऊपर रखें -

using System;

namespace BoxApplication {

   class Box {
      private double length;   // Length of a box
      private double breadth;  // Breadth of a box
      private double height;   // Height of a box
      
      public void setLength( double len ) {
         length = len;
      }
      
      public void setBreadth( double bre ) {
         breadth = bre;
      }
      
      public void setHeight( double hei ) {
         height = hei;
      }
      public double getVolume() {
         return length * breadth * height;
      }
   }
   
   class Boxtester {
   
      static void Main(string[] args) {
         Box Box1 = new Box();   // Declare Box1 of type Box
         Box Box2 = new Box();
         double volume;
         
         // Declare Box2 of type Box
         // box 1 specification
         Box1.setLength(6.0);
         Box1.setBreadth(7.0);
         Box1.setHeight(5.0);
         
         // box 2 specification
         Box2.setLength(12.0);
         Box2.setBreadth(13.0);
         Box2.setHeight(10.0);
         
         // volume of box 1
         volume = Box1.getVolume();
         Console.WriteLine("Volume of Box1 : {0}" ,volume);
         
         // volume of box 2
         volume = Box2.getVolume();
         Console.WriteLine("Volume of Box2 : {0}", volume);
         
         Console.ReadKey();
      }
   }
}

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

Volume of Box1 : 210
Volume of Box2 : 1560

सी # कंस्ट्रक्टर्स

एक कक्षा constructor एक वर्ग का एक विशेष सदस्य कार्य है जिसे तब भी निष्पादित किया जाता है जब हम उस वर्ग की नई वस्तुओं का निर्माण करते हैं।

एक कंस्ट्रक्टर का ठीक वैसा ही नाम होता है जैसा क्लास का होता है और उसमें कोई रिटर्न टाइप नहीं होता है। उदाहरण के बाद निर्माता की अवधारणा को समझाता है -

using System;

namespace LineApplication {

   class Line {
      private double length;   // Length of a line
      
      public Line() {
         Console.WriteLine("Object is being created");
      }

      public void setLength( double len ) {
         length = len;
      }
      
      public double getLength() {
         return length;
      }

      static void Main(string[] args) {
         Line line = new Line();    
         
         // set line length
         line.setLength(6.0);
         Console.WriteLine("Length of line : {0}", line.getLength());
         Console.ReadKey();
      }
   }
}

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

Object is being created
Length of line : 6

default constructorकोई पैरामीटर नहीं है, लेकिन अगर आपको ज़रूरत है, तो एक निर्माणकर्ता के पास पैरामीटर हो सकते हैं। ऐसे निर्माणकर्ता कहलाते हैंparameterized constructors। यह तकनीक आपको इसके निर्माण के समय किसी वस्तु को प्रारंभिक मूल्य प्रदान करने में मदद करती है जैसा कि निम्नलिखित उदाहरण में दिखाया गया है -

using System;

namespace LineApplication {

   class Line {
      private double length;   // Length of a line
      
      public Line(double len) {  //Parameterized constructor
         Console.WriteLine("Object is being created, length = {0}", len);
         length = len;
      }

      public void setLength( double len ) {
         length = len;
      }
      
      public double getLength() {
         return length;
      }

      static void Main(string[] args) {
         Line line = new Line(10.0);
         Console.WriteLine("Length of line : {0}", line.getLength()); 
         
         // set line length
         line.setLength(6.0);
         Console.WriteLine("Length of line : {0}", line.getLength()); 
         Console.ReadKey();
      }
   }
}

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

Object is being created, length = 10
Length of line : 10
Length of line : 6

सी # डिस्ट्रक्टर्स

destructorएक वर्ग का एक विशेष सदस्य कार्य है जिसे तब भी निष्पादित किया जाता है जब उसकी कक्षा का कोई ऑब्जेक्ट कार्यक्षेत्र से बाहर हो जाता है। एdestructor ठीक उसी नाम का है जैसा कि एक उपसर्गित टिल्ड (~) के साथ वर्ग का है और यह न तो कोई मान लौटा सकता है और न ही यह कोई पैरामीटर ले सकता है।

कार्यक्रम से बाहर निकलने से पहले स्मृति संसाधनों को जारी करने के लिए विध्वंसक बहुत उपयोगी हो सकता है। विध्वंसक विरासत में प्राप्त या अधिभारित नहीं किए जा सकते हैं।

निम्नलिखित उदाहरण विध्वंसक की अवधारणा को बताते हैं -

using System;

namespace LineApplication {

   class Line {
      private double length;   // Length of a line
      
      public Line() {   // constructor
         Console.WriteLine("Object is being created");
      }
      
      ~Line() {   //destructor
         Console.WriteLine("Object is being deleted");
      }

      public void setLength( double len ) {
         length = len;
      }

      public double getLength() {
         return length;
      }

      static void Main(string[] args) {
         Line line = new Line();

         // set line length
         line.setLength(6.0);
         Console.WriteLine("Length of line : {0}", line.getLength());           
      }
   }
}

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

Object is being created
Length of line : 6
Object is being deleted

C # वर्ग के स्थिर सदस्य

हम कक्षा सदस्यों को स्थिर का उपयोग करके परिभाषित कर सकते हैं staticकीवर्ड। जब हम किसी वर्ग के सदस्य को स्थैतिक घोषित करते हैं, तो इसका मतलब यह है कि कक्षा की कितनी वस्तुएं बनी हैं, स्थैतिक सदस्य की केवल एक प्रति है।

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

निम्नलिखित उदाहरण के उपयोग को दर्शाता है static variables -

using System;

namespace StaticVarApplication {

   class StaticVar {
      public static int num;
      
      public void count() {
         num++;
      }
      
      public int getNum() {
         return num;
      }
   }
   
   class StaticTester {
   
      static void Main(string[] args) {
         StaticVar s1 = new StaticVar();
         StaticVar s2 = new StaticVar();
         s1.count();
         s1.count();
         s1.count();
         s2.count();
         s2.count();
         s2.count();
         Console.WriteLine("Variable num for s1: {0}", s1.getNum());
         Console.WriteLine("Variable num for s2: {0}", s2.getNum());
         Console.ReadKey();
      }
   }
}

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

Variable num for s1: 6
Variable num for s2: 6

आप भी घोषणा कर सकते हैं member function जैसा static। इस तरह के कार्य केवल स्थिर चर तक पहुंच सकते हैं। वस्तु के बनने से पहले ही स्थैतिक कार्य मौजूद हैं। निम्नलिखित उदाहरण के उपयोग को दर्शाता हैstatic functions -

using System;

namespace StaticVarApplication {

   class StaticVar {
      public static int num;
      
      public void count() {
         num++;
      }
      
      public static int getNum() {
         return num;
      }
   }
   
   class StaticTester {
   
      static void Main(string[] args) {
         StaticVar s = new StaticVar();
         s.count();
         s.count();
         s.count();
         Console.WriteLine("Variable num: {0}", StaticVar.getNum());
         Console.ReadKey();
      }
   }
}

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

Variable num: 3

ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग में सबसे महत्वपूर्ण अवधारणाओं में से एक विरासत है। वंशानुक्रम हमें एक वर्ग को दूसरी कक्षा के संदर्भ में परिभाषित करने की अनुमति देता है, जिससे एप्लिकेशन बनाना और उसे बनाए रखना आसान हो जाता है। इससे कोड कार्यक्षमता का पुन: उपयोग करने और कार्यान्वयन समय को गति देने का अवसर भी मिलता है।

कक्षा बनाते समय, पूरी तरह से नए डेटा सदस्यों और सदस्य कार्यों को लिखने के बजाय, प्रोग्रामर यह नामित कर सकता है कि नए वर्ग को किसी मौजूदा वर्ग के सदस्यों को विरासत में प्राप्त करना चाहिए। इस मौजूदा वर्ग को कहा जाता हैbase वर्ग, और नए वर्ग के रूप में जाना जाता है derived कक्षा।

उत्तराधिकार का विचार लागू करता है IS-Aरिश्ते। उदाहरण के लिए, स्तनपायीIS A जानवर, कुत्ता IS-A स्तनपायी इसलिए कुत्ता IS-A पशु के रूप में अच्छी तरह से, और इतने पर।

आधार और व्युत्पन्न वर्ग

एक वर्ग को एक से अधिक वर्ग या इंटरफ़ेस से प्राप्त किया जा सकता है, जिसका अर्थ है कि यह कई बेस क्लास या इंटरफेस से डेटा और फ़ंक्शंस विरासत में प्राप्त कर सकता है।

व्युत्पन्न वर्ग बनाने के लिए C # में प्रयुक्त सिंटैक्स निम्नानुसार है -

<acess-specifier> class <base_class> {
   ...
}

class <derived_class> : <base_class> {
   ...
}

बेस क्लास शेप और उसके व्युत्पन्न वर्ग आयत पर विचार करें -

using System;

namespace InheritanceApplication {
   
   class Shape {
      
      public void setWidth(int w) {
         width = w;
      }
      
      public void setHeight(int h) {
         height = h;
      }
      protected int width;
      protected int height;
   }

   // Derived class
   class Rectangle: Shape {
      
      public int getArea() { 
         return (width * height); 
      }
   }
   
   class RectangleTester {
   
      static void Main(string[] args) {
         Rectangle Rect = new Rectangle();

         Rect.setWidth(5);
         Rect.setHeight(7);

         // Print the area of the object.
         Console.WriteLine("Total area: {0}",  Rect.getArea());
         Console.ReadKey();
      }
   }
}

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

Total area: 35

बेस क्लास की शुरुआत

व्युत्पन्न वर्ग बेस क्लास सदस्य चर और सदस्य विधियों को विरासत में मिला है। इसलिए उपवर्ग बनाने से पहले सुपर क्लास ऑब्जेक्ट बनाया जाना चाहिए। आप सदस्य प्रारंभिक सूची में सुपरक्लास आरंभीकरण के लिए निर्देश दे सकते हैं।

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

using System;

namespace RectangleApplication {

   class Rectangle {
      //member variables
      protected double length;
      protected double width;
      
      public Rectangle(double l, double w) {
         length = l;
         width = w;
      }
      
      public double GetArea() {
         return length * width;
      }
      
      public void Display() {
         Console.WriteLine("Length: {0}", length);
         Console.WriteLine("Width: {0}", width);
         Console.WriteLine("Area: {0}", GetArea());
      }
   }//end class Rectangle  
   
   class Tabletop : Rectangle {
      private double cost;
      public Tabletop(double l, double w) : base(l, w) { }
      
      public double GetCost() {
         double cost;
         cost = GetArea() * 70;
         return cost;
      }
      
      public void Display() {
         base.Display();
         Console.WriteLine("Cost: {0}", GetCost());
      }
   }
   
   class ExecuteRectangle {
      
      static void Main(string[] args) {
         Tabletop t = new Tabletop(4.5, 7.5);
         t.Display();
         Console.ReadLine();
      }
   }
}

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

Length: 4.5
Width: 7.5
Area: 33.75
Cost: 2362.5

C # में कई वंशानुक्रम

C# does not support multiple inheritance। हालाँकि, आप कई वंशानुक्रम को लागू करने के लिए इंटरफ़ेस का उपयोग कर सकते हैं। निम्नलिखित कार्यक्रम यह प्रदर्शित करता है -

using System;

namespace InheritanceApplication {
   
   class Shape {
      
      public void setWidth(int w) {
         width = w;
      }
      
      public void setHeight(int h) {
         height = h;
      }
      protected int width;
      protected int height;
   }

   // Base class PaintCost
   public interface PaintCost {
      int getCost(int area);
   }
   
   // Derived class
   class Rectangle : Shape, PaintCost {
      
      public int getArea() {
         return (width * height);
      }
      
      public int getCost(int area) {
         return area * 70;
      }
   }
   
   class RectangleTester {
      
      static void Main(string[] args) {
         Rectangle Rect = new Rectangle();
         int area;
         Rect.setWidth(5);
         Rect.setHeight(7);
         area = Rect.getArea();
         
         // Print the area of the object.
         Console.WriteLine("Total area: {0}",  Rect.getArea());
         Console.WriteLine("Total paint cost: ${0}" , Rect.getCost(area));
         Console.ReadKey();
      }
   }
}

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

Total area: 35
Total paint cost: $2450

शब्द polymorphismकई रूपों का मतलब है। ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग प्रतिमान में, बहुरूपता को अक्सर 'एक इंटरफ़ेस, कई फ़ंक्शन' के रूप में व्यक्त किया जाता है।

बहुरूपता स्थिर या गतिशील हो सकती है। मेंstatic polymorphismकिसी फ़ंक्शन की प्रतिक्रिया को संकलन समय पर निर्धारित किया जाता है। मेंdynamic polymorphism, यह रन-टाइम पर तय किया जाता है।

स्थैतिक बहुरूपता

संकलित समय के दौरान किसी फ़ंक्शन को किसी ऑब्जेक्ट के साथ जोड़ने के तंत्र को प्रारंभिक बाध्यकारी कहा जाता है। इसे स्थैतिक बंधन भी कहा जाता है। C # स्थिर बहुरूपता को लागू करने के लिए दो तकनीक प्रदान करता है। वे हैं -

  • कार्य अतिभार
  • ऑपरेटर ओवरलोडिंग

हम अगले अध्याय में ऑपरेटर ओवरलोडिंग पर चर्चा करते हैं।

ओवरलोडिंग

समान दायरे में समान फ़ंक्शन नाम के लिए आपके पास कई परिभाषाएँ हो सकती हैं। फ़ंक्शन की परिभाषा तर्क सूची में प्रकारों और / या तर्कों की संख्या से एक दूसरे से भिन्न होनी चाहिए। आप फ़ंक्शन घोषणाओं को ओवरलोड नहीं कर सकते हैं जो केवल रिटर्न प्रकार से भिन्न होते हैं।

निम्न उदाहरण फ़ंक्शन का उपयोग करके दिखाता है print() विभिन्न प्रकार के डेटा को प्रिंट करने के लिए -

using System;

namespace PolymorphismApplication {

   class Printdata {
   
      void print(int i) {
         Console.WriteLine("Printing int: {0}", i );
      }

      void print(double f) {
         Console.WriteLine("Printing float: {0}" , f);
      }

      void print(string s) {
         Console.WriteLine("Printing string: {0}", s);
      }
      
      static void Main(string[] args) {
         Printdata p = new Printdata();
         
         // Call print to print integer
         p.print(5);
         
         // Call print to print float
         p.print(500.263);
         
         // Call print to print string
         p.print("Hello C++");
         Console.ReadKey();
      }
   }
}

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

Printing int: 5
Printing float: 500.263
Printing string: Hello C++

गतिशील बहुरूपता

C # आपको अमूर्त कक्षाएं बनाने की अनुमति देता है जो एक इंटरफ़ेस के आंशिक वर्ग कार्यान्वयन प्रदान करने के लिए उपयोग की जाती हैं। कार्यान्वयन तब पूरा होता है जब एक व्युत्पन्न वर्ग इससे विरासत में मिलता है।Abstractकक्षाओं में अमूर्त विधियां होती हैं, जिन्हें व्युत्पन्न वर्ग द्वारा कार्यान्वित किया जाता है। व्युत्पन्न वर्गों में अधिक विशिष्ट कार्यक्षमता है।

यहाँ सार वर्गों के बारे में नियम हैं -

  • आप एक अमूर्त वर्ग का उदाहरण नहीं बना सकते

  • आप एक अमूर्त वर्ग के बाहर एक सार पद्धति की घोषणा नहीं कर सकते

  • जब एक वर्ग घोषित किया जाता है sealed, यह विरासत में नहीं मिल सकता है, अमूर्त वर्गों को सील घोषित नहीं किया जा सकता है।

निम्नलिखित कार्यक्रम एक अमूर्त वर्ग प्रदर्शित करता है -

using System;

namespace PolymorphismApplication {

   abstract class Shape {
      public abstract int area();
   }
   
   class Rectangle:  Shape {
      private int length;
      private int width;
      
      public Rectangle( int a = 0, int b = 0) {
         length = a;
         width = b;
      }
      
      public override int area () { 
         Console.WriteLine("Rectangle class area :");
         return (width * length); 
      }
   }

   class RectangleTester {
      
      static void Main(string[] args) {
         Rectangle r = new Rectangle(10, 7);
         double a = r.area();
         Console.WriteLine("Area: {0}",a);
         Console.ReadKey();
      }
   }
}

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

Rectangle class area :
Area: 70

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

डायनेमिक बहुरूपता द्वारा कार्यान्वित किया जाता है abstract classes तथा virtual functions

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

using System;

namespace PolymorphismApplication {

   class Shape {
      protected int width, height;
      
      public Shape( int a = 0, int b = 0) {
         width = a;
         height = b;
      }
      
      public virtual int area() {
         Console.WriteLine("Parent class area :");
         return 0;
      }
   }
   
   class Rectangle: Shape {
      public Rectangle( int a = 0, int b = 0): base(a, b) {

      }
      
      public override int area () {
         Console.WriteLine("Rectangle class area :");
         return (width * height); 
      }
   }
   
   class Triangle: Shape {
      public Triangle(int a = 0, int b = 0): base(a, b) {
      
      }
      
      public override int area() {
         Console.WriteLine("Triangle class area :");
         return (width * height / 2); 
      }
   }
   
   class Caller {
      public void CallArea(Shape sh) {
         int a;
         a = sh.area();
         Console.WriteLine("Area: {0}", a);
      }
   }  
   
   class Tester {

      static void Main(string[] args) {
         Caller c = new Caller();
         Rectangle r = new Rectangle(10, 7);
         Triangle t = new Triangle(10, 5);
         c.CallArea(r);
         c.CallArea(t);
         Console.ReadKey();
      }
   }
}

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

Rectangle class area:
Area: 70
Triangle class area:
Area: 25

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

उदाहरण के लिए, निम्नलिखित फ़ंक्शन के माध्यम से जाना -

public static Box operator+ (Box b, Box c) {
   Box box = new Box();
   box.length = b.length + c.length;
   box.breadth = b.breadth + c.breadth;
   box.height = b.height + c.height;
   return box;
}

उपर्युक्त फ़ंक्शन उपयोगकर्ता-परिभाषित क्लास बॉक्स के लिए अतिरिक्त ऑपरेटर (+) लागू करता है। यह दो बॉक्स ऑब्जेक्ट की विशेषताओं को जोड़ता है और परिणामी बॉक्स ऑब्जेक्ट को लौटाता है।

ऑपरेटर ओवरलोडिंग को लागू करना

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

using System;

namespace OperatorOvlApplication {

   class Box {
      private double length;   // Length of a box
      private double breadth;  // Breadth of a box
      private double height;   // Height of a box

      public double getVolume() {
         return length * breadth * height;
      }
      
      public void setLength( double len ) {
         length = len;
      }

      public void setBreadth( double bre ) {
         breadth = bre;
      }

      public void setHeight( double hei ) {
         height = hei;
      }
      
      // Overload + operator to add two Box objects.
      public static Box operator+ (Box b, Box c) {
         Box box = new Box();
         box.length = b.length + c.length;
         box.breadth = b.breadth + c.breadth;
         box.height = b.height + c.height;
         return box;
      }
   }

   class Tester {
   
      static void Main(string[] args) {
         Box Box1 = new Box();   // Declare Box1 of type Box
         Box Box2 = new Box();   // Declare Box2 of type Box
         Box Box3 = new Box();   // Declare Box3 of type Box
         double volume = 0.0;    // Store the volume of a box here

         // box 1 specification
         Box1.setLength(6.0);
         Box1.setBreadth(7.0);
         Box1.setHeight(5.0);

         // box 2 specification
         Box2.setLength(12.0);
         Box2.setBreadth(13.0);
         Box2.setHeight(10.0);

         // volume of box 1
         volume = Box1.getVolume();
         Console.WriteLine("Volume of Box1 : {0}", volume);

         // volume of box 2
         volume = Box2.getVolume();
         Console.WriteLine("Volume of Box2 : {0}", volume);

         // Add two object as follows:
         Box3 = Box1 + Box2;

         // volume of box 3
         volume = Box3.getVolume();
         Console.WriteLine("Volume of Box3 : {0}", volume);
         Console.ReadKey();
      }
   }
}

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

Volume of Box1 : 210
Volume of Box2 : 1560
Volume of Box3 : 5400

अधिभार और गैर-अधिभार संचालक

निम्नलिखित तालिका में सी # में ऑपरेटरों की अधिभार क्षमता का वर्णन है -

अनु क्रमांक। ऑपरेटर और विवरण
1

+, -, !, ~, ++, --

ये एकतरफा ऑपरेटर एक ऑपरेंड लेते हैं और इसे ओवरलोड किया जा सकता है।

2

+, -, *, /, %

ये बाइनरी ऑपरेटर एक ऑपरेंड लेते हैं और इसे ओवरलोड किया जा सकता है।

3

==, !=, <, >, <=, >=

तुलना ऑपरेटरों को ओवरलोड किया जा सकता है।

4

&&, ||

सशर्त तार्किक ऑपरेटरों को सीधे ओवरलोड नहीं किया जा सकता है।

5

+=, -=, *=, /=, %=

असाइनमेंट ऑपरेटर्स को ओवरलोड नहीं किया जा सकता है।

6

=, ., ?:, ->, new, is, sizeof, typeof

इन ऑपरेटरों को ओवरलोड नहीं किया जा सकता है।

उदाहरण

उपरोक्त चर्चाओं के प्रकाश में, आइए हम पूर्ववर्ती उदाहरण का विस्तार करें, और कुछ और ऑपरेटरों को अधिभारित करें -

using System;

namespace OperatorOvlApplication {

   class Box {
      private double length;    // Length of a box
      private double breadth;   // Breadth of a box
      private double height;    // Height of a box
      
      public double getVolume() {
         return length * breadth * height;
      }
      
      public void setLength( double len ) {
         length = len;
      }
      
      public void setBreadth( double bre ) {
         breadth = bre;
      }
      
      public void setHeight( double hei ) {
         height = hei;
      }
      
      // Overload + operator to add two Box objects.
      public static Box operator+ (Box b, Box c) {
         Box box = new Box();
         box.length = b.length + c.length;
         box.breadth = b.breadth + c.breadth;
         box.height = b.height + c.height;
         return box;
      }

      public static bool operator == (Box lhs, Box rhs) {
         bool status = false;
         if (lhs.length == rhs.length && lhs.height == rhs.height && lhs.breadth == rhs.breadth) {
            status = true;
         }
         return status;
      }
      
      public static bool operator !=(Box lhs, Box rhs) {
         bool status = false;
         
         if (lhs.length != rhs.length || lhs.height != rhs.height || lhs.breadth != rhs.breadth) {
            status = true;
         }
         return status;
      }
      
      public static bool operator <(Box lhs, Box rhs) {
         bool status = false;
         
         if (lhs.length < rhs.length && lhs.height < rhs.height && lhs.breadth < rhs.breadth) {
            status = true;
         }
         return status;
      }
      
      public static bool operator >(Box lhs, Box rhs) {
         bool status = false;
         
         if (lhs.length > rhs.length && lhs.height > rhs.height && lhs.breadth > rhs.breadth) {
            status = true;
         }
         return status;
      }
      
      public static bool operator <=(Box lhs, Box rhs) {
         bool status = false;
         
         if (lhs.length <= rhs.length && lhs.height <= rhs.height && lhs.breadth <= rhs.breadth) {
            status = true;
         }
         return status;
      }
      
      public static bool operator >=(Box lhs, Box rhs) {
         bool status = false;
         
         if (lhs.length >= rhs.length && lhs.height >= rhs.height && lhs.breadth >= rhs.breadth) {
            status = true;
         }
         return status;
      }
      
      public override string ToString() {
         return String.Format("({0}, {1}, {2})", length, breadth, height);
      }
   }
   
   class Tester {
   
      static void Main(string[] args) {
         Box Box1 = new Box();   // Declare Box1 of type Box
         Box Box2 = new Box();   // Declare Box2 of type Box
         Box Box3 = new Box();   // Declare Box3 of type Box
         Box Box4 = new Box();
         double volume = 0.0;    // Store the volume of a box here
         
         // box 1 specification
         Box1.setLength(6.0);
         Box1.setBreadth(7.0);
         Box1.setHeight(5.0);
         
         // box 2 specification
         Box2.setLength(12.0);
         Box2.setBreadth(13.0);
         Box2.setHeight(10.0);
         
         //displaying the Boxes using the overloaded ToString():
         Console.WriteLine("Box 1: {0}", Box1.ToString());
         Console.WriteLine("Box 2: {0}", Box2.ToString());
         
         // volume of box 1
         volume = Box1.getVolume();
         Console.WriteLine("Volume of Box1 : {0}", volume);
         
         // volume of box 2
         volume = Box2.getVolume();
         Console.WriteLine("Volume of Box2 : {0}", volume);
         
         // Add two object as follows:
         Box3 = Box1 + Box2;
         Console.WriteLine("Box 3: {0}", Box3.ToString());
         
         // volume of box 3
         volume = Box3.getVolume();
         Console.WriteLine("Volume of Box3 : {0}", volume);
         
         //comparing the boxes
         if (Box1 > Box2)
            Console.WriteLine("Box1 is greater than Box2");
         else
            Console.WriteLine("Box1 is  greater than Box2");
         
         if (Box1 < Box2)
            Console.WriteLine("Box1 is less than Box2");
         else
            Console.WriteLine("Box1 is not less than Box2");
         
         if (Box1 >= Box2)
            Console.WriteLine("Box1 is greater or equal to Box2");
         else
            Console.WriteLine("Box1 is not greater or equal to Box2");
         
         if (Box1 <= Box2)
            Console.WriteLine("Box1 is less or equal to Box2");
         else
            Console.WriteLine("Box1 is not less or equal to Box2");
         
         if (Box1 != Box2)
            Console.WriteLine("Box1 is not equal to Box2");
         else
            Console.WriteLine("Box1 is not greater or equal to Box2");
         Box4 = Box3;
         
         if (Box3 == Box4)
            Console.WriteLine("Box3 is equal to Box4");
         else
            Console.WriteLine("Box3 is not equal to Box4");

         Console.ReadKey();
      }
   }
}

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

Box 1: (6, 7, 5)
Box 2: (12, 13, 10)
Volume of Box1 : 210
Volume of Box2 : 1560
Box 3: (18, 20, 15)
Volume of Box3 : 5400
Box1 is not greater than Box2
Box1 is less than Box2
Box1 is not greater or equal to Box2
Box1 is less or equal to Box2
Box1 is not equal to Box2
Box3 is equal to Box4

एक इंटरफेस को एक सिंटैक्टिकल कॉन्ट्रैक्ट के रूप में परिभाषित किया गया है जो कि इंटरफ़ेस को प्राप्त करने वाले सभी वर्गों का पालन करना चाहिए। इंटरफ़ेस परिभाषित करता है'what' सिंटैक्टिकल अनुबंध और व्युत्पन्न वर्गों का हिस्सा परिभाषित करता है 'how' सिंटैक्टिकल अनुबंध का हिस्सा।

इंटरफेस गुणों, विधियों और घटनाओं को परिभाषित करते हैं, जो इंटरफ़ेस के सदस्य हैं। इंटरफेस में केवल सदस्यों की घोषणा होती है। यह व्युत्पन्न वर्ग की जिम्मेदारी है कि वह सदस्यों को परिभाषित करे। यह अक्सर एक मानक संरचना प्रदान करने में मदद करता है जो व्युत्पन्न वर्ग का पालन करेगा।

कुछ हद तक सार कक्षाएं एक ही उद्देश्य की सेवा करती हैं, हालांकि, उनका उपयोग ज्यादातर तब किया जाता है जब बेस क्लास द्वारा केवल कुछ विधियों को घोषित किया जाता है और व्युत्पन्न वर्ग कार्यात्मकता को लागू करता है।

घोषणाओं को समाप्त करना

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

public interface ITransactions {
   // interface members
   void showTransaction();
   double getAmount();
}

उदाहरण

निम्नलिखित उदाहरण उपरोक्त इंटरफ़ेस के कार्यान्वयन को दर्शाता है -

using System.Collections.Generic;
using System.Linq;
using System.Text;
using System;

namespace InterfaceApplication {
   
   public interface ITransactions {
      // interface members
      void showTransaction();
      double getAmount();
   }
   
   public class Transaction : ITransactions {
      private string tCode;
      private string date;
      private double amount;
      
      public Transaction() {
         tCode = " ";
         date = " ";
         amount = 0.0;
      }
      
      public Transaction(string c, string d, double a) {
         tCode = c;
         date = d;
         amount = a;
      }
      
      public double getAmount() {
         return amount;
      }
      
      public void showTransaction() {
         Console.WriteLine("Transaction: {0}", tCode);
         Console.WriteLine("Date: {0}", date);
         Console.WriteLine("Amount: {0}", getAmount());
      }
   }
   
   class Tester {
     
      static void Main(string[] args) {
         Transaction t1 = new Transaction("001", "8/10/2012", 78900.00);
         Transaction t2 = new Transaction("002", "9/10/2012", 451900.00);
         t1.showTransaction();
         t2.showTransaction();
         Console.ReadKey();
      }
   }
}

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

Transaction: 001
Date: 8/10/2012
Amount: 78900
Transaction: 002
Date: 9/10/2012
Amount: 451900

namespaceएक नाम को दूसरे से अलग रखने का एक तरीका प्रदान करने के लिए डिज़ाइन किया गया है। एक नाम स्थान में घोषित वर्ग नाम दूसरे में घोषित समान वर्ग नामों के साथ संघर्ष नहीं करता है।

एक नाम स्थान परिभाषित करना

एक नाम स्थान की परिभाषा कीवर्ड से शुरू होती है namespace इसके बाद नाम स्थान के नाम के साथ -

namespace namespace_name {
   // code declarations
}

फ़ंक्शन या वैरिएबल के नेमस्पेस-सक्षम संस्करण को कॉल करने के लिए, इस प्रकार से नेमस्पेस नाम को प्रस्तुत करें -

namespace_name.item_name;

निम्नलिखित कार्यक्रम नेमस्पेस के उपयोग को प्रदर्शित करता है -

using System;

namespace first_space {

   class namespace_cl {
   
      public void func() {
         Console.WriteLine("Inside first_space");
      }
   }
}

namespace second_space {

   class namespace_cl {
   
      public void func() {
         Console.WriteLine("Inside second_space");
      }
   }
}

class TestClass {

   static void Main(string[] args) {
      first_space.namespace_cl fc = new first_space.namespace_cl();
      second_space.namespace_cl sc = new second_space.namespace_cl();
      fc.func();
      sc.func();
      Console.ReadKey();
   }
}

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

Inside first_space
Inside second_space

कीवर्ड का उपयोग कर

usingकीवर्ड बताता है कि प्रोग्राम दिए गए नेमस्पेस में नामों का उपयोग कर रहा है। उदाहरण के लिए, हम उपयोग कर रहे हैंSystemहमारे कार्यक्रमों में नाम स्थान। क्लास कंसोल को वहां परिभाषित किया गया है। हम सिर्फ लिखते हैं -

Console.WriteLine ("Hello there");

हम पूरी तरह से योग्य नाम लिख सकते हैं -

System.Console.WriteLine("Hello there");

आप के साथ नाम स्थान के प्रीपेडिंग से भी बच सकते हैं usingनेमस्पेस निर्देश। यह निर्देश संकलक को बताता है कि बाद का कोड निर्दिष्ट नामस्थान में नामों का उपयोग कर रहा है। नेमस्पेस इस प्रकार निम्नलिखित कोड के लिए निहित है -

हमें निर्देशन का उपयोग करने के साथ, हमारे पूर्ववर्ती उदाहरण को फिर से लिखना चाहिए -

using System;
using first_space;
using second_space;

namespace first_space {

   class abc {
   
      public void func() {
         Console.WriteLine("Inside first_space");
      }
   }
}

namespace second_space {

   class efg {
   
      public void func() {
         Console.WriteLine("Inside second_space");
      }
   }
}   

class TestClass {

   static void Main(string[] args) {
      abc fc = new abc();
      efg sc = new efg();
      fc.func();
      sc.func();
      Console.ReadKey();
   }
}

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

Inside first_space
Inside second_space

नेस्टेड नेमस्पेस

आप एक नामस्थान को दूसरे नामस्थान के अंदर परिभाषित कर सकते हैं -

namespace namespace_name1 {
   
   // code declarations
   namespace namespace_name2 {
      // code declarations
   }
}

आप निम्नांकित नाम स्थान के सदस्यों को निम्नानुसार डॉट (।) ऑपरेटर का उपयोग करके देख सकते हैं -

using System;
using first_space;
using first_space.second_space;

namespace first_space {

   class abc {
   
      public void func() {
         Console.WriteLine("Inside first_space");
      }
   }
   
   namespace second_space {
   
      class efg {
      
         public void func() {
            Console.WriteLine("Inside second_space");
         }
      }
   }   
}
 
class TestClass {

   static void Main(string[] args) {
      abc fc = new abc();
      efg sc = new efg();
      fc.func();
      sc.func();
      Console.ReadKey();
   }
}

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

Inside first_space
Inside second_space

प्रीप्रोसेसर निर्देशक कंपाइलर को वास्तविक संकलन शुरू होने से पहले सूचना को प्रीप्रोसेस करने के निर्देश देते हैं।

सभी प्रीप्रोसेसर निर्देश # से शुरू होते हैं, और एक लाइन पर प्रीप्रोसेसर निर्देश से पहले केवल सफेद-अंतरिक्ष वर्ण दिखाई दे सकते हैं। प्रीप्रोसेसर निर्देश कथन नहीं हैं, इसलिए वे अर्धविराम (;) के साथ समाप्त नहीं होते हैं।

सी # कंपाइलर में एक अलग प्रीप्रोसेसर नहीं है; हालाँकि, निर्देशों को संसाधित किया जाता है जैसे कि एक था। सी # में प्रीप्रोसेसर निर्देशकों का उपयोग सशर्त संकलन में मदद करने के लिए किया जाता है। सी और सी ++ निर्देशों के विपरीत, वे मैक्रोज़ बनाने के लिए उपयोग नहीं किए जाते हैं। एक पूर्वप्रक्रमक निर्देश केवल एक लाइन पर निर्देश होना चाहिए।

C # में प्रीप्रोसेसर के निर्देश

निम्न तालिका C # में उपलब्ध प्रीप्रोसेसर निर्देशों को सूचीबद्ध करती है।

अनु क्रमांक। प्रीप्रोसेसर निर्देश और विवरण
1

#define

यह वर्णों के एक क्रम को परिभाषित करता है, जिसे प्रतीक कहा जाता है।

2

#undef

यह आपको एक प्रतीक को अपरिभाषित करने की अनुमति देता है।

3

#if

यह एक प्रतीक या प्रतीकों का परीक्षण करने की अनुमति देता है यह देखने के लिए कि क्या वे सच का मूल्यांकन करते हैं।

4

#else

यह #if के साथ एक कंपाउंड कंडीशनल डायरेक्टिव बनाने की अनुमति देता है।

5

#elif

यह एक यौगिक सशर्त निर्देश बनाने की अनुमति देता है।

6

#endif

एक सशर्त निर्देश के अंत को निर्दिष्ट करता है।

7

#line

यह आपको संकलक की पंक्ति संख्या और (वैकल्पिक रूप से) फ़ाइल नाम आउटपुट को त्रुटियों और चेतावनियों के लिए संशोधित करने देता है।

8

#error

यह आपके कोड में एक विशिष्ट स्थान से एक त्रुटि उत्पन्न करने की अनुमति देता है।

9

#warning

यह आपके कोड में एक विशिष्ट स्थान से एक स्तर की चेतावनी उत्पन्न करने की अनुमति देता है।

10

#region

यह आपको कोड का एक ब्लॉक निर्दिष्ट करने देता है जिसे आप Visual Studio कोड एडिटर की आउटलाइनिंग सुविधा का उपयोग करते समय विस्तार या पतन कर सकते हैं।

1 1

#endregion

यह एक # समूह ब्लॉक के अंत को चिह्नित करता है।

#Define प्रीप्रोसेसर

#Define प्रीप्रोसेसर निर्देश प्रतीकात्मक स्थिरांक बनाता है।

#define आपको एक प्रतीक को परिभाषित करने देता है, जो कि प्रतीक का उपयोग करते हुए, अभिव्यक्ति को #if निर्देश पर पारित किया जाता है, अभिव्यक्ति सत्य का मूल्यांकन करती है। इसका सिंटैक्स इस प्रकार है -

#define symbol

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

#define PI 
using System;

namespace PreprocessorDAppl {

   class Program {
   
      static void Main(string[] args) {
         #if (PI)
            Console.WriteLine("PI is defined");
         #else
            Console.WriteLine("PI is not defined");
         #endif
         Console.ReadKey();
      }
   }
}

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

PI is defined

सशर्त निर्देश

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

सशर्त निर्देश के लिए सिंटैक्स है -

#if symbol [operator symbol]...

जहां, प्रतीक उस प्रतीक का नाम है जिसे आप परीक्षण करना चाहते हैं। आप नकारात्मक ऑपरेटर के साथ भी सही और गलत का उपयोग कर सकते हैं या प्रतीक को रोक सकते हैं।

ऑपरेटर प्रतीक प्रतीक के मूल्यांकन के लिए प्रयोग किया जाता है ऑपरेटर है। ऑपरेटर निम्नलिखित में से कोई भी हो सकते हैं -

  • == (समानता)
  • = (असमानता)
  • && (तथा)
  • || (या)

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

निम्नलिखित कार्यक्रम सशर्त निर्देशों के उपयोग को दर्शाता है -

#define DEBUG
#define VC_V10
using System;

public class TestClass {

   public static void Main() {
      #if (DEBUG && !VC_V10)
         Console.WriteLine("DEBUG is defined");
      #elif (!DEBUG && VC_V10)
         Console.WriteLine("VC_V10 is defined");
      #elif (DEBUG && VC_V10)
         Console.WriteLine("DEBUG and VC_V10 are defined");
      #else
         Console.WriteLine("DEBUG and VC_V10 are not defined");
      #endif
      Console.ReadKey();
   }
}

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

DEBUG and VC_V10 are defined

regular expressionएक पैटर्न है जिसे इनपुट टेक्स्ट के खिलाफ मिलान किया जा सकता है। .Net फ्रेमवर्क एक नियमित अभिव्यक्ति इंजन प्रदान करता है जो इस तरह के मिलान की अनुमति देता है। एक पैटर्न में एक या अधिक चरित्र शाब्दिक, ऑपरेटर या निर्माण शामिल होते हैं।

नियमित अभिव्यक्तियों को परिभाषित करने के लिए निर्माण

पात्रों, ऑपरेटरों और निर्माणों की विभिन्न श्रेणियां हैं जो आपको नियमित अभिव्यक्तियों को परिभाषित करने की अनुमति देती हैं। इन निर्माणों को खोजने के लिए निम्न लिंक पर क्लिक करें।

  • चरित्र बच जाता है

  • चरित्र वर्ग

  • Anchors

  • समूह निर्माण

  • Quantifiers

  • पश्चगामी निर्माण करता है

  • वैकल्पिक निर्माण

  • Substitutions

  • विविध निर्माण

द रेगेक्स क्लास

रेगेक्स वर्ग का उपयोग एक नियमित अभिव्यक्ति का प्रतिनिधित्व करने के लिए किया जाता है। इसके निम्नलिखित सामान्य तरीके हैं -

अनु क्रमांक। तरीके और विवरण
1

public bool IsMatch(string input)

इंगित करता है कि Regex कंस्ट्रक्टर में निर्दिष्ट नियमित अभिव्यक्ति एक निर्दिष्ट इनपुट स्ट्रिंग में एक मैच पाता है या नहीं।

2

public bool IsMatch(string input, int startat)

इंगित करता है कि क्या रेगेक्स कंस्ट्रक्टर में निर्दिष्ट नियमित अभिव्यक्ति निर्दिष्ट इनपुट स्ट्रिंग में एक मिलान पाता है, जो स्ट्रिंग में निर्दिष्ट शुरुआती स्थिति में है।

3

public static bool IsMatch(string input, string pattern)

इंगित करता है कि निर्दिष्ट नियमित अभिव्यक्ति निर्दिष्ट इनपुट स्ट्रिंग में एक मैच पाता है या नहीं।

4

public MatchCollection Matches(string input)

एक नियमित अभिव्यक्ति के सभी घटनाओं के लिए निर्दिष्ट इनपुट स्ट्रिंग खोजता है।

5

public string Replace(string input, string replacement)

एक निर्दिष्ट इनपुट स्ट्रिंग में, सभी स्ट्रिंग को प्रतिस्थापित करता है जो एक निर्दिष्ट प्रतिस्थापन स्ट्रिंग के साथ एक नियमित अभिव्यक्ति पैटर्न से मेल खाते हैं।

6

public string[] Split(string input)

रेगेक्स कंस्ट्रक्टर में निर्दिष्ट एक रेगुलर एक्सप्रेशन पैटर्न द्वारा परिभाषित पदों पर एक इनपुट स्ट्रिंग को सब्सट्रिंग्स के एक हिस्से में विभाजित करता है।

विधियों और गुणों की पूरी सूची के लिए, कृपया C # पर Microsoft दस्तावेज़ पढ़ें।

उदाहरण 1

निम्नलिखित उदाहरण 'S' से शुरू होने वाले शब्दों से मेल खाते हैं -

using System;
using System.Text.RegularExpressions;

namespace RegExApplication {

   class Program {
   
      private static void showMatch(string text, string expr) {
         Console.WriteLine("The Expression: " + expr);
         MatchCollection mc = Regex.Matches(text, expr);
         foreach (Match m in mc) {
            Console.WriteLine(m);
         }
      }
      
      static void Main(string[] args) {
         string str = "A Thousand Splendid Suns";
         
         Console.WriteLine("Matching words that start with 'S': ");
         showMatch(str, @"\bS\S*");
         Console.ReadKey();
      }
   }
}

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

Matching words that start with 'S':
The Expression: \bS\S*
Splendid
Suns

उदाहरण 2

निम्नलिखित उदाहरण ऐसे शब्दों से मेल खाते हैं जो 'm' से शुरू होते हैं और 'e' से समाप्त होते हैं -

using System;
using System.Text.RegularExpressions;

namespace RegExApplication {

   class Program {
      private static void showMatch(string text, string expr) {
         Console.WriteLine("The Expression: " + expr);
         MatchCollection mc = Regex.Matches(text, expr);
         foreach (Match m in mc) {
            Console.WriteLine(m);
         }
      }
      static void Main(string[] args) {
         string str = "make maze and manage to measure it";

         Console.WriteLine("Matching words start with 'm' and ends with 'e':");
         showMatch(str, @"\bm\S*e\b");
         Console.ReadKey();
      }
   }
}

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

Matching words start with 'm' and ends with 'e':
The Expression: \bm\S*e\b
make
maze
manage
measure

उदाहरण 3

यह उदाहरण अतिरिक्त सफेद स्थान की जगह लेता है -

using System;
using System.Text.RegularExpressions;

namespace RegExApplication {

   class Program {
   
      static void Main(string[] args) {
         string input = "Hello   World   ";
         string pattern = "\\s+";
         string replacement = " ";
         Regex rgx = new Regex(pattern);
         string result = rgx.Replace(input, replacement);

         Console.WriteLine("Original String: {0}", input);
         Console.WriteLine("Replacement String: {0}", result);    
         Console.ReadKey();
      }
   }
}

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

Original String: Hello World   
Replacement String: Hello World

एक अपवाद एक समस्या है जो एक कार्यक्रम के निष्पादन के दौरान उत्पन्न होती है। एसी # अपवाद एक असाधारण परिस्थिति की प्रतिक्रिया है जो किसी कार्यक्रम को चलाने के दौरान उत्पन्न होती है, जैसे कि शून्य से विभाजित करने का प्रयास।

अपवाद प्रोग्राम के एक भाग से दूसरे में नियंत्रण स्थानांतरित करने का एक तरीका प्रदान करते हैं। C # अपवाद हैंडलिंग चार कीवर्ड पर बनाया गया है:try, catch, finally, तथा throw

  • try- एक कोशिश ब्लॉक कोड के एक ब्लॉक की पहचान करता है जिसके लिए विशेष अपवाद सक्रिय है। इसके बाद एक या एक से अधिक कैच ब्लॉक होते हैं।

  • catch- एक कार्यक्रम एक अपवाद हैंडलर के साथ एक अपवाद को एक कार्यक्रम में उस स्थान पर पकड़ता है जहां आप समस्या को संभालना चाहते हैं। कैच कीवर्ड अपवाद को पकड़ने का संकेत देता है।

  • finally- अंततः ब्लॉक का उपयोग दिए गए कथनों के सेट को निष्पादित करने के लिए किया जाता है, चाहे कोई अपवाद फेंका जाए या नहीं। उदाहरण के लिए, यदि आप कोई फ़ाइल खोलते हैं, तो उसे बंद कर दिया जाना चाहिए, चाहे कोई अपवाद उठाया गया हो या नहीं।

  • throw- जब कोई समस्या दिखाई देती है तो एक प्रोग्राम एक अपवाद को फेंक देता है। यह एक थ्रो कीवर्ड का उपयोग करके किया जाता है।

वाक्य - विन्यास

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

try {
   // statements causing exception
} catch( ExceptionName e1 ) {
   // error handling code
} catch( ExceptionName e2 ) {
   // error handling code
} catch( ExceptionName eN ) {
   // error handling code
} finally {
   // statements to be executed
}

आप विभिन्न स्थितियों में एक से अधिक अपवादों को उठाने की स्थिति में विभिन्न प्रकार के अपवादों को पकड़ने के लिए कई कैच स्टेटमेंट्स को सूचीबद्ध कर सकते हैं।

C # में अपवाद कक्षाएं

C # अपवाद वर्गों द्वारा दर्शाए गए हैं। C # में अपवाद वर्ग मुख्य रूप से प्रत्यक्ष या अप्रत्यक्ष रूप से हैंSystem.Exceptionकक्षा। कुछ अपवाद क्लासेस System.Exception क्लास से व्युत्पन्न हैंSystem.ApplicationException तथा System.SystemException कक्षाएं।

System.ApplicationExceptionवर्ग आवेदन कार्यक्रमों द्वारा उत्पन्न अपवादों का समर्थन करता है। इसलिए प्रोग्रामर द्वारा परिभाषित अपवादों को इस वर्ग से लिया जाना चाहिए।

System.SystemException क्लास सभी पूर्वनिर्धारित सिस्टम अपवाद के लिए बेस क्लास है।

निम्नलिखित तालिका Sytem.SystemException वर्ग से प्राप्त पूर्वनिर्धारित अपवाद वर्गों में से कुछ प्रदान करती है -

अनु क्रमांक। अपवाद कक्षा और विवरण
1

System.IO.IOException

I / O त्रुटियों को संभालता है।

2

System.IndexOutOfRangeException

जब कोई विधि किसी सरणी अनुक्रमणिका को सीमा से बाहर संदर्भित करती है, तो उत्पन्न त्रुटियां।

3

System.ArrayTypeMismatchException

टाइप प्रकार के साथ बेमेल होने पर हैंडल की गई त्रुटियां उत्पन्न होती हैं।

4

System.NullReferenceException

एक अशक्त वस्तु को संदर्भित करने से उत्पन्न त्रुटियों को संभालता है।

5

System.DivideByZeroException

शून्य से लाभांश को विभाजित करने से उत्पन्न त्रुटियों को संभालता है।

6

System.InvalidCastException

टाइपकास्टिंग के दौरान उत्पन्न त्रुटियों को संभालता है।

7

System.OutOfMemoryException

अपर्याप्त मुक्त मेमोरी से उत्पन्न त्रुटियों को संभालता है।

8

System.StackOverflowException

स्टैक ओवरफ्लो से उत्पन्न त्रुटियों को संभालता है।

अपवादों को संभालना

C # कोशिश और ब्लॉक को पकड़ने के रूप में अपवाद से निपटने के लिए एक संरचित समाधान प्रदान करता है। इन ब्लॉकों का उपयोग करके कोर प्रोग्राम स्टेटमेंट्स को त्रुटि-हैंडलिंग स्टेटमेंट्स से अलग किया जाता है।

इन त्रुटि हैंडलिंग ब्लॉकों का उपयोग करके कार्यान्वित किया जाता है try, catch, तथा finallyकीवर्ड। शून्य स्थिति से विभाजित होने पर अपवाद फेंकने का एक उदाहरण निम्नलिखित है -

using System;

namespace ErrorHandlingApplication {

   class DivNumbers {
      int result;
      
      DivNumbers() {
         result = 0;
      }
      
      public void division(int num1, int num2) {
         try {
            result = num1 / num2;
         } catch (DivideByZeroException e) {
            Console.WriteLine("Exception caught: {0}", e);
         } finally {
            Console.WriteLine("Result: {0}", result);
         }
      }
      
      static void Main(string[] args) {
         DivNumbers d = new DivNumbers();
         d.division(25, 0);
         Console.ReadKey();
      }
   }
}

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

Exception caught: System.DivideByZeroException: Attempted to divide by zero. 
at ...
Result: 0

उपयोगकर्ता-परिभाषित अपवाद बनाना

आप अपने स्वयं के अपवाद को भी परिभाषित कर सकते हैं। उपयोगकर्ता-परिभाषित अपवाद वर्ग से प्राप्त होते हैंExceptionकक्षा। निम्न उदाहरण यह प्रदर्शित करता है -

using System;

namespace UserDefinedException {

   class TestTemperature {
   
      static void Main(string[] args) {
         Temperature temp = new Temperature();
         try {
            temp.showTemp();
         } catch(TempIsZeroException e) {
            Console.WriteLine("TempIsZeroException: {0}", e.Message);
         }
         Console.ReadKey();
      }
   }
}

public class TempIsZeroException: Exception {

   public TempIsZeroException(string message): base(message) {
   
   }
}

public class Temperature {
   int temperature = 0;
   
   public void showTemp() {
      
      if(temperature == 0) {
         throw (new TempIsZeroException("Zero Temperature found"));
      } else {
         Console.WriteLine("Temperature: {0}", temperature);
      }
   }
}

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

TempIsZeroException: Zero Temperature found

वस्तुओं को फेंकना

आप एक वस्तु को फेंक सकते हैं यदि यह या तो प्रत्यक्ष या परोक्ष रूप से है System.Exceptionकक्षा। आप वर्तमान वस्तु को फेंकने के लिए कैच ब्लॉक में फेंक स्टेटमेंट का उपयोग कर सकते हैं -

Catch(Exception e) {
   ...
   Throw e
}

fileएक विशिष्ट नाम और निर्देशिका पथ के साथ डिस्क में संग्रहीत डेटा का एक संग्रह है। जब कोई फ़ाइल पढ़ने या लिखने के लिए खोली जाती है, तो यह एक हो जाती हैstream

धारा मूल रूप से संचार पथ से गुजरने वाले बाइट्स का अनुक्रम है। दो मुख्य धाराएँ हैं: दinput stream और यह output stream input stream फ़ाइल (रीड ऑपरेशन) से डेटा पढ़ने के लिए उपयोग किया जाता है और output stream फ़ाइल में लिखने के लिए प्रयोग किया जाता है (ऑपरेशन लिखें)।

C # I / O वर्ग

System.IO नेमस्पेस में विभिन्न वर्ग होते हैं जिनका उपयोग फाइलों के साथ कई ऑपरेशन करने के लिए किया जाता है, जैसे कि फाइल बनाना और हटाना, फाइल से पढ़ना या लिखना, फाइल बंद करना आदि।

निम्न तालिका System.IO नाम स्थान में कुछ सामान्य रूप से उपयोग किए जाने वाले गैर-अमूर्त वर्गों को दिखाती है -

अनु क्रमांक। मैं / हे वर्ग और विवरण
1

BinaryReader

एक बाइनरी स्ट्रीम से आदिम डेटा पढ़ता है।

2

BinaryWriter

बाइनरी प्रारूप में आदिम डेटा लिखता है।

3

BufferedStream

बाइट्स की एक धारा के लिए एक अस्थायी भंडारण।

4

Directory

एक निर्देशिका संरचना में हेरफेर करने में मदद करता है।

5

DirectoryInfo

निर्देशिकाओं पर संचालन करने के लिए उपयोग किया जाता है।

6

DriveInfo

ड्राइव के लिए जानकारी प्रदान करता है।

7

File

फाइलों में हेरफेर करने में मदद करता है।

8

FileInfo

फ़ाइलों पर कार्रवाई करने के लिए उपयोग किया जाता है।

9

FileStream

फ़ाइल में किसी भी स्थान से पढ़ने और लिखने के लिए उपयोग किया जाता है।

10

MemoryStream

मेमोरी में संग्रहीत स्ट्रीम किए गए डेटा तक यादृच्छिक पहुंच के लिए उपयोग किया जाता है।

1 1

Path

पथ सूचना पर संचालन करता है।

12

StreamReader

एक बाइट स्ट्रीम से वर्ण पढ़ने के लिए उपयोग किया जाता है।

13

StreamWriter

एक धारा में वर्ण लिखने के लिए उपयोग किया जाता है।

14

StringReader

एक स्ट्रिंग बफर से पढ़ने के लिए उपयोग किया जाता है।

15

StringWriter

एक स्ट्रिंग बफर में लिखने के लिए उपयोग किया जाता है।

FileStream क्लास

FileStreamSystem.IO नामस्थान में कक्षा से पढ़ने, लिखने और फाइलों को बंद करने में मदद मिलती है। यह वर्ग अमूर्त वर्ग स्ट्रीम से निकला है।

आपको एक बनाने की आवश्यकता है FileStreamऑब्जेक्ट एक नई फ़ाइल बनाने या एक मौजूदा फ़ाइल खोलने के लिए। एक बनाने के लिए वाक्यविन्यासFileStream वस्तु इस प्रकार है -

FileStream <object_name> = new FileStream( <file_name>, <FileMode Enumerator>,
   <FileAccess Enumerator>, <FileShare Enumerator>);

उदाहरण के लिए, हम एक FileStream ऑब्जेक्ट बनाते हैं F नाम की एक फाइल पढ़ने के लिए sample.txt as shown -

FileStream F = new FileStream("sample.txt", FileMode.Open, FileAccess.Read,
   FileShare.Read);
अनु क्रमांक। पैरामीटर और विवरण
1

FileMode

FileModeEnumerator फाइलें खोलने के लिए विभिन्न तरीकों को परिभाषित करता है। FileMode प्रगणक के सदस्य हैं -

  • Append - यह एक मौजूदा फ़ाइल खोलता है और फ़ाइल के अंत में कर्सर डालता है, या फ़ाइल बनाता है, अगर फ़ाइल मौजूद नहीं है।

  • Create - यह एक नई फ़ाइल बनाता है।

  • CreateNew - यह ऑपरेटिंग सिस्टम को निर्दिष्ट करता है, कि इसे एक नई फ़ाइल बनाना चाहिए।

  • Open - यह एक मौजूदा फ़ाइल खोलता है।

  • OpenOrCreate - यह ऑपरेटिंग सिस्टम के लिए निर्दिष्ट करता है कि यह मौजूद होने पर एक फ़ाइल खोलना चाहिए, अन्यथा इसे एक नई फ़ाइल बनाना चाहिए।

  • Truncate - यह एक मौजूदा फ़ाइल को खोलता है और इसके आकार को शून्य बाइट्स में विभाजित करता है।

2

FileAccess

FileAccess प्रगणकों के सदस्य हैं: Read, ReadWrite तथा Write

3

FileShare

FileShare प्रगणकों में निम्नलिखित सदस्य हैं -

  • Inheritable - यह फ़ाइल को बच्चे की प्रक्रियाओं में विरासत को पारित करने की अनुमति देता है

  • None - यह वर्तमान फ़ाइल के साझाकरण को घटाता है

  • Read - यह रीडिन के लिए फाइल खोलने की अनुमति देता है।

  • ReadWrite - यह पढ़ने और लिखने के लिए फ़ाइल खोलने की अनुमति देता है

  • Write - यह लिखने के लिए फ़ाइल खोलने की अनुमति देता है

उदाहरण

निम्नलिखित कार्यक्रम के उपयोग को दर्शाता है FileStream वर्ग -

using System;
using System.IO;

namespace FileIOApplication {
   
   class Program {
      
      static void Main(string[] args) {
         FileStream F = new FileStream("test.dat", FileMode.OpenOrCreate, 
            FileAccess.ReadWrite);
         
         for (int i = 1; i <= 20; i++) {
            F.WriteByte((byte)i);
         }
         
         F.Position = 0;
         for (int i = 0; i <= 20; i++) {
            Console.Write(F.ReadByte() + " ");
         }
         F.Close();
         Console.ReadKey();
      }
   }
}

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

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 -1

C # में उन्नत फ़ाइल संचालन

पूर्ववर्ती उदाहरण C # में सरल फ़ाइल संचालन प्रदान करता है। हालाँकि, C # System.IO वर्गों की अपार शक्तियों का उपयोग करने के लिए, आपको इन वर्गों के सामान्य रूप से उपयोग किए जाने वाले गुणों और तरीकों को जानना होगा।

अनु क्रमांक। विषय विवरण
1 पाठ फ़ाइलों में से पढ़ना और लिखना

इसमें पाठ फ़ाइलों में पढ़ना और लिखना शामिल है। StreamReader तथा StreamWriter वर्ग इसे पूरा करने में मदद करता है।

2 बाइनरी फाइलों में पढ़ना और लिखना

इसमें बाइनरी फाइलों में पढ़ना और लिखना शामिल है। BinaryReader तथा BinaryWriter कक्षा इसे पूरा करने में मदद करती है।

3 विंडोज फाइल सिस्टम को मैनिप्युलेट करना

यह एक सी # प्रोग्रामर को विंडोज फाइलों और निर्देशिकाओं को ब्राउज़ करने और खोजने की क्षमता देता है।

एक attributeएक घोषणात्मक टैग है जिसका उपयोग आपके कार्यक्रम में विभिन्न तत्वों जैसे कि कक्षाओं, विधियों, संरचनाओं, प्रगणकों, विधानसभाओं आदि के व्यवहार के बारे में जानकारी देने के लिए किया जाता है। आप किसी विशेषता का उपयोग करके किसी प्रोग्राम में घोषणात्मक जानकारी जोड़ सकते हैं। एक घोषणात्मक टैग को वर्ग ([]) कोष्ठक द्वारा दर्शाया गया है जो उस तत्व के ऊपर रखा गया है जिसके लिए इसका उपयोग किया जाता है।

गुणक का उपयोग मेटाडेटा को जोड़ने के लिए किया जाता है, जैसे संकलक निर्देश और अन्य जानकारी जैसे किसी कार्यक्रम में टिप्पणी, विवरण, विधियाँ और कक्षाएं। .Net फ्रेमवर्क दो प्रकार की विशेषताएँ प्रदान करता है: पूर्व-निर्धारित विशेषताएँ और कस्टम निर्मित विशेषताएँ।

विशेषता बताना

किसी विशेषता को निर्दिष्ट करने के लिए सिंटैक्स इस प्रकार है -

[attribute(positional_parameters, name_parameter = value, ...)]
element

विशेषता के नाम और उसके मान को वर्ग कोष्ठक के भीतर निर्दिष्ट किया जाता है, जिस तत्व के लिए विशेषता को लागू किया जाता है। स्थितिगत पैरामीटर आवश्यक जानकारी निर्दिष्ट करते हैं और नाम पैरामीटर वैकल्पिक जानकारी निर्दिष्ट करते हैं।

पूर्वनिर्धारित गुण

.Net फ्रेमवर्क तीन पूर्व-परिभाषित विशेषताएं प्रदान करता है -

  • AttributeUsage
  • Conditional
  • Obsolete

AttributeUsage

पूर्व-परिभाषित विशेषता AttributeUsageवर्णन करता है कि कस्टम विशेषता वर्ग का उपयोग कैसे किया जा सकता है। यह उन वस्तुओं के प्रकारों को निर्दिष्ट करता है जिनके लिए विशेषता को लागू किया जा सकता है।

इस विशेषता को निर्दिष्ट करने के लिए सिंटैक्स इस प्रकार है -

[AttributeUsage (
   validon,
   AllowMultiple = allowmultiple,
   Inherited = inherited
)]

कहाँ पे,

  • पैरामीटर मान्य भाषा विशेषताओं को निर्दिष्ट करता है, जिस पर विशेषता रखी जा सकती है। यह एक एन्यूमरेटर एट्रीब्यूटटार्गेट्स के मूल्य का एक संयोजन है । डिफ़ॉल्ट मान AttributeTargets.All है

  • पैरामीटर allowmultiple (वैकल्पिक) इस विशेषता की AllowMultiple संपत्ति के लिए मूल्य प्रदान करता है , एक बूलियन मूल्य। यदि यह सत्य है, तो गुण बहु है। डिफ़ॉल्ट गलत है (एकल-उपयोग)।

  • इनहेरिट किया गया पैरामीटर (वैकल्पिक) इस विशेषता की इनहेरिट की गई संपत्ति के लिए मूल्य प्रदान करता है , एक बूलियन मूल्य। यदि यह सही है, तो विशेषता व्युत्पन्न वर्गों द्वारा विरासत में मिली है। डिफ़ॉल्ट मान गलत है (विरासत में नहीं)।

उदाहरण के लिए,

[AttributeUsage(AttributeTargets.Class |
AttributeTargets.Constructor |
AttributeTargets.Field |
AttributeTargets.Method |
AttributeTargets.Property, 
AllowMultiple = true)]

सशर्त

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

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

इस विशेषता को निर्दिष्ट करने के लिए सिंटैक्स इस प्रकार है -

[Conditional(
   conditionalSymbol
)]

उदाहरण के लिए,

[Conditional("DEBUG")]

निम्न उदाहरण विशेषता प्रदर्शित करता है -

#define DEBUG
using System;
using System.Diagnostics;

public class Myclass {
   [Conditional("DEBUG")]
   
   public static void Message(string msg) {
      Console.WriteLine(msg);
   }
}

class Test {
   static void function1() {
      Myclass.Message("In Function 1.");
      function2();
   }
   
   static void function2() {
      Myclass.Message("In Function 2.");
   }
   
   public static void Main() {
      Myclass.Message("In Main function.");
      function1();
      Console.ReadKey();
   }
}

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

In Main function
In Function 1
In Function 2

अप्रचलित

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

इस विशेषता को निर्दिष्ट करने के लिए सिंटैक्स इस प्रकार है -

[Obsolete (
   message
)]

[Obsolete (
   message,
   iserror
)]

कहाँ पे,

  • पैरामीटर संदेश , एक स्ट्रिंग है जो इस कारण का वर्णन करता है कि आइटम अप्रचलित है और इसके बजाय क्या उपयोग करना है।

  • पैरामीटर ISERROR , एक बूलियन मान है। यदि इसका मान सही है, तो संकलक को आइटम के त्रुटि के रूप में उपयोग करना चाहिए। डिफ़ॉल्ट मान गलत है (संकलक एक चेतावनी उत्पन्न करता है)।

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

using System;

public class MyClass {
   [Obsolete("Don't use OldMethod, use NewMethod instead", true)]
   
   static void OldMethod() {
      Console.WriteLine("It is the old method");
   }
   
   static void NewMethod() {
      Console.WriteLine("It is the new method"); 
   }
   
   public static void Main() {
      OldMethod();
   }
}

जब आप प्रोग्राम को संकलित करने का प्रयास करते हैं, तो संकलक एक त्रुटि संदेश देता है -

Don't use OldMethod, use NewMethod instead

कस्टम विशेषताएँ बनाना

.Net फ्रेमवर्क उन कस्टम विशेषताओं के निर्माण की अनुमति देता है, जिनका उपयोग घोषणात्मक जानकारी को संग्रहीत करने के लिए किया जा सकता है और रन-टाइम पर पुनर्प्राप्त किया जा सकता है। यह जानकारी किसी भी लक्ष्य तत्व से संबंधित हो सकती है जो डिजाइन मानदंड और आवेदन की आवश्यकता पर निर्भर करता है।

कस्टम विशेषताएँ बनाना और उपयोग करना चार चरणों में शामिल है -

  • एक कस्टम विशेषता की घोषणा
  • कस्टम विशेषता का निर्माण
  • लक्ष्य कार्यक्रम तत्व पर कस्टम विशेषता लागू करें
  • परावर्तन के माध्यम से प्रवेश करना

अंतिम चरण में मेटाडेटा के माध्यम से पढ़ने के लिए विभिन्न संकेतन खोजने के लिए एक सरल कार्यक्रम लिखना शामिल है। मेटाडेटा डेटा या अन्य डेटा का वर्णन करने के लिए उपयोग की जाने वाली जानकारी के बारे में डेटा है। इस कार्यक्रम को रनटाइम पर विशेषताओं तक पहुंचने के लिए प्रतिबिंबों का उपयोग करना चाहिए। यह हम अगले अध्याय में चर्चा करेंगे।

एक कस्टम विशेषता की घोषणा

एक नई कस्टम विशेषता से लिया जाना चाहिए System.Attributeकक्षा। उदाहरण के लिए,

//a custom attribute BugFix to be assigned to a class and its members
[AttributeUsage(AttributeTargets.Class |
AttributeTargets.Constructor |
AttributeTargets.Field |
AttributeTargets.Method |
AttributeTargets.Property,
AllowMultiple = true)]

public class DeBugInfo : System.Attribute

पूर्ववर्ती कोड में, हमने DeBugInfo नामक एक कस्टम विशेषता घोषित की है ।

कस्टम विशेषता का निर्माण

आइए हम DeBugInfo नामक एक कस्टम विशेषता का निर्माण करते हैं , जो किसी भी प्रोग्राम को डीबग करके प्राप्त जानकारी को संग्रहीत करता है। इसे निम्नलिखित जानकारी संग्रहीत करने दें -

  • बग के लिए कोड संख्या
  • बग की पहचान करने वाले डेवलपर का नाम
  • कोड की अंतिम समीक्षा की तारीख
  • डेवलपर की टिप्पणियों को संग्रहीत करने के लिए एक स्ट्रिंग संदेश

DebugInfo वर्ग के पहले तीन जानकारी और संदेश के भंडारण के लिए एक सार्वजनिक संपत्ति के भंडारण के लिए तीन निजी गुण है। इसलिए बग नंबर, डेवलपर का नाम, और समीक्षा की तारीख DeBugInfo वर्ग के स्थितीय पैरामीटर हैं और संदेश एक वैकल्पिक या नामित पैरामीटर है।

प्रत्येक विशेषता में कम से कम एक निर्माता होना चाहिए। निर्माता के माध्यम से स्थितीय मापदंडों को पारित किया जाना चाहिए। निम्नलिखित कोड DeBugInfo वर्ग दिखाता है -

//a custom attribute BugFix to be assigned to a class and its members
[AttributeUsage(AttributeTargets.Class |
AttributeTargets.Constructor |
AttributeTargets.Field |
AttributeTargets.Method |
AttributeTargets.Property,
AllowMultiple = true)]

public class DeBugInfo : System.Attribute {
   private int bugNo;
   private string developer;
   private string lastReview;
   public string message;
   
   public DeBugInfo(int bg, string dev, string d) {
      this.bugNo = bg;
      this.developer = dev;
      this.lastReview = d;
   }

   public int BugNo {
      get {
         return bugNo;
      }
   }
   
   public string Developer {
      get {
         return developer;
      }
   }
   
   public string LastReview {
      get {
         return lastReview;
      }
   }
   
   public string Message {
      get {
         return message;
      }
      set {
         message = value;
      }
   }
}

कस्टम विशेषता को लागू करना

विशेषता को उसके लक्ष्य से ठीक पहले लगाकर लागू किया जाता है -

[DeBugInfo(45, "Zara Ali", "12/8/2012", Message = "Return type mismatch")]
[DeBugInfo(49, "Nuha Ali", "10/10/2012", Message = "Unused variable")]
class Rectangle {
   //member variables
   protected double length;
   protected double width;
   public Rectangle(double l, double w) {
      length = l;
      width = w;
   }
   [DeBugInfo(55, "Zara Ali", "19/10/2012", Message = "Return type mismatch")]
   
   public double GetArea() {
      return length * width;
   }
   [DeBugInfo(56, "Zara Ali", "19/10/2012")]
   
   public void Display() {
      Console.WriteLine("Length: {0}", length);
      Console.WriteLine("Width: {0}", width);
      Console.WriteLine("Area: {0}", GetArea());
   }
}

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

Reflectionरनटाइम पर टाइप जानकारी प्राप्त करने के लिए वस्तुओं का उपयोग किया जाता है। कक्षाएं जो चल रहे प्रोग्राम के मेटाडेटा तक पहुंच प्रदान करती हैंSystem.Reflection नाम स्थान।

System.Reflection नेमस्पेस में वे कक्षाएं होती हैं जो आपको एप्लिकेशन के बारे में जानकारी प्राप्त करने और गतिशील रूप से एप्लिकेशन में प्रकार, मान और ऑब्जेक्ट जोड़ने की अनुमति देती हैं।

प्रतिबिंब के अनुप्रयोग

प्रतिबिंब में निम्नलिखित अनुप्रयोग हैं -

  • यह रनटाइम पर विशेषता जानकारी देखने की अनुमति देता है।

  • यह एक विधानसभा में विभिन्न प्रकारों की जांच करने और इन प्रकारों को तुरंत करने की अनुमति देता है।

  • यह विधियों और गुणों के लिए देर से बाध्यकारी है

  • यह रनटाइम पर नए प्रकार बनाने की अनुमति देता है और फिर उन प्रकारों का उपयोग करके कुछ कार्य करता है।

मेटाडाटा देखना

हमने पूर्ववर्ती अध्याय में उल्लेख किया है कि प्रतिबिंब का उपयोग करके आप विशेषता जानकारी देख सकते हैं।

MemberInfo की वस्तु System.Reflectionवर्ग से जुड़ी विशेषताओं की खोज के लिए वर्ग को आरंभीकृत करने की आवश्यकता है। ऐसा करने के लिए, आप लक्ष्य वर्ग की एक वस्तु को परिभाषित करते हैं, जैसे -

System.Reflection.MemberInfo info = typeof(MyClass);

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

using System;

[AttributeUsage(AttributeTargets.All)]
public class HelpAttribute : System.Attribute {
   public readonly string Url;
   
   public string Topic   // Topic is a named parameter {
      get {
         return topic;
      }
      
      set {
         topic = value;
      }
   }
   
   public HelpAttribute(string url)   // url is a positional parameter {
      this.Url = url;
   }
   private string topic;
}

[HelpAttribute("Information on the class MyClass")]
class MyClass {

}

namespace AttributeAppl {

   class Program {
   
      static void Main(string[] args) {
         System.Reflection.MemberInfo info = typeof(MyClass);
         object[] attributes = info.GetCustomAttributes(true);
         for (int i = 0; i < attributes.Length; i++) {
            System.Console.WriteLine(attributes[i]);
         }
         Console.ReadKey();
      }
   }
}

जब इसे संकलित और चलाया जाता है, तो यह क्लास MyClass से जुड़ी कस्टम विशेषताओं का नाम प्रदर्शित करता है -

HelpAttribute

उदाहरण

इस उदाहरण में, हम पिछले अध्याय में बनाए गए DeBugInfo विशेषता का उपयोग करते हैं और आयत वर्ग में मेटाडेटा पढ़ने के लिए प्रतिबिंब का उपयोग करते हैं ।

using System;
using System.Reflection;

namespace BugFixApplication {
   //a custom attribute BugFix to be
   //assigned to a class and its members
   [AttributeUsage(AttributeTargets.Class |
   AttributeTargets.Constructor |
   AttributeTargets.Field |
   AttributeTargets.Method |
   AttributeTargets.Property,
   AllowMultiple = true)]

   public class DeBugInfo : System.Attribute {
      private int bugNo;
      private string developer;
      private string lastReview;
      public string message;
      
      public DeBugInfo(int bg, string dev, string d) {
         this.bugNo = bg;
         this.developer = dev;
         this.lastReview = d;
      }
      
      public int BugNo {
         get {
            return bugNo;
         }
      }
      
      public string Developer {
         get {
            return developer;
         }
      }
      
      public string LastReview {
         get {
            return lastReview;
         }
      }
      
      public string Message {
         get {
            return message;
         }
         set {
            message = value;
         }
      }
   }
   [DeBugInfo(45, "Zara Ali", "12/8/2012", Message = "Return type mismatch")]
   [DeBugInfo(49, "Nuha Ali", "10/10/2012", Message = "Unused variable")]
   
   class Rectangle {
      //member variables
      protected double length;
      protected double width;
      public Rectangle(double l, double w) {
         length = l;
         width = w;
      }
      
      [DeBugInfo(55, "Zara Ali", "19/10/2012", Message = "Return type mismatch")]
      public double GetArea() {
         return length * width;
      }
      
      [DeBugInfo(56, "Zara Ali", "19/10/2012")]
      public void Display() {
         Console.WriteLine("Length: {0}", length);
         Console.WriteLine("Width: {0}", width);
         Console.WriteLine("Area: {0}", GetArea());
      }
   }//end class Rectangle
   
   class ExecuteRectangle {
      static void Main(string[] args) {
         Rectangle r = new Rectangle(4.5, 7.5);
         r.Display();
         Type type = typeof(Rectangle);
         
         //iterating through the attribtues of the Rectangle class
         foreach (Object attributes in type.GetCustomAttributes(false)) {
            DeBugInfo dbi = (DeBugInfo)attributes;
            
            if (null != dbi) {
               Console.WriteLine("Bug no: {0}", dbi.BugNo);
               Console.WriteLine("Developer: {0}", dbi.Developer);
               Console.WriteLine("Last Reviewed: {0}", dbi.LastReview);
               Console.WriteLine("Remarks: {0}", dbi.Message);
            }
         }

         //iterating through the method attribtues
         foreach (MethodInfo m in type.GetMethods()) {
            
            foreach (Attribute a in m.GetCustomAttributes(true)) {
               DeBugInfo dbi = (DeBugInfo)a;
               
               if (null != dbi) {
                  Console.WriteLine("Bug no: {0}, for Method: {1}", dbi.BugNo, m.Name);
                  Console.WriteLine("Developer: {0}", dbi.Developer);
                  Console.WriteLine("Last Reviewed: {0}", dbi.LastReview);
                  Console.WriteLine("Remarks: {0}", dbi.Message);
               }
            }
         }
         Console.ReadLine();
      }
   }
}

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

Length: 4.5
Width: 7.5
Area: 33.75
Bug No: 49
Developer: Nuha Ali
Last Reviewed: 10/10/2012
Remarks: Unused variable
Bug No: 45
Developer: Zara Ali
Last Reviewed: 12/8/2012
Remarks: Return type mismatch
Bug No: 55, for Method: GetArea
Developer: Zara Ali
Last Reviewed: 19/10/2012
Remarks: Return type mismatch
Bug No: 56, for Method: Display
Developer: Zara Ali
Last Reviewed: 19/10/2012
Remarks:

Propertiesकक्षाओं, संरचनाओं और इंटरफेस के सदस्यों के नाम हैं। एक वर्ग या संरचनाओं में सदस्य चर या विधियों को कहा जाता हैFields। गुण फ़ील्ड्स का एक एक्सटेंशन हैं और समान सिंटैक्स का उपयोग करके एक्सेस किए जाते हैं। वे उपयोग करते हैंaccessors जिसके माध्यम से निजी क्षेत्रों के मूल्यों को पढ़ा, लिखा या हेरफेर किया जा सकता है।

गुण भंडारण स्थानों का नाम नहीं देते हैं। इसके बजाय, उनके पास हैaccessors उनके मूल्यों को पढ़ें, लिखें या गणना करें।

उदाहरण के लिए, हमारे पास एक वर्ग है जिसका नाम छात्र है, उम्र, नाम और कोड के लिए निजी क्षेत्रों के साथ। हम इन क्षेत्रों को सीधे वर्ग के दायरे से बाहर नहीं कर सकते हैं, लेकिन हमारे पास इन निजी क्षेत्रों तक पहुँचने के लिए गुण हो सकते हैं।

पहुंचकर्ता

accessorकिसी संपत्ति में निष्पादन योग्य कथन होते हैं जो संपत्ति को प्राप्त करने (पढ़ने या कंप्यूटिंग) या स्थापित करने (लिखने) में मदद करते हैं। एक्सेसर घोषणाओं में एक एक्सेस एक्सेसर, एक सेट एक्सेसर या दोनों हो सकते हैं। उदाहरण के लिए -

// Declare a Code property of type string:
public string Code {
   get {
      return code;
   }
   set {
      code = value;
   }
}

// Declare a Name property of type string:
public string Name {
   get {
      return name;
   }
   set {
      name = value;
   }
}

// Declare a Age property of type int:
public int Age { 
   get {
      return age;
   }
   set {
      age = value;
   }
}

उदाहरण

निम्नलिखित उदाहरण गुणों के उपयोग को दर्शाता है -

using System;
namespace tutorialspoint {
   class Student {
      private string code = "N.A";
      private string name = "not known";
      private int age = 0;
      
      // Declare a Code property of type string:
      public string Code {
         get {
            return code;
         }
         set {
            code = value;
         }
      }
      
      // Declare a Name property of type string:
      public string Name {
         get {
            return name;
         }
         set {
            name = value;
         }
      }
      
      // Declare a Age property of type int:
      public int Age {
         get {
            return age;
         }
         set {
            age = value;
         }
      }
      public override string ToString() {
         return "Code = " + Code +", Name = " + Name + ", Age = " + Age;
      }
   }
   
   class ExampleDemo {
      public static void Main() {
      
         // Create a new Student object:
         Student s = new Student();
         
         // Setting code, name and the age of the student
         s.Code = "001";
         s.Name = "Zara";
         s.Age = 9;
         Console.WriteLine("Student Info: {0}", s);
         
         //let us increase age
         s.Age += 1;
         Console.WriteLine("Student Info: {0}", s);
         Console.ReadKey();
      }
   }
}

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

Student Info: Code = 001, Name = Zara, Age = 9
Student Info: Code = 001, Name = Zara, Age = 10

सार गुण

एक अमूर्त वर्ग में एक अमूर्त संपत्ति हो सकती है, जिसे व्युत्पन्न वर्ग में लागू किया जाना चाहिए। निम्नलिखित कार्यक्रम यह दिखाता है -

using System;
namespace tutorialspoint {
   public abstract class Person {
      public abstract string Name {
         get;
         set;
      }
      public abstract int Age {
         get;
         set;
      }
   }
   
   class Student : Person {
   
      private string code = "N.A";
      private string name = "N.A";
      private int age = 0;
      
      // Declare a Code property of type string:
      public string Code {
         get {
            return code;
         }
         set {
            code = value;
         }
      }
      
      // Declare a Name property of type string:
      public override string Name {
         get {
            return name;
         }
         set {
            name = value;
         }
      }
      
      // Declare a Age property of type int:
      public override int Age {
         get {
            return age;
         }
         set {
            age = value;
         }
      }
      public override string ToString() {
         return "Code = " + Code +", Name = " + Name + ", Age = " + Age;
      }
   }
   
   class ExampleDemo {
      public static void Main() {
         // Create a new Student object:
         Student s = new Student();
         
         // Setting code, name and the age of the student
         s.Code = "001";
         s.Name = "Zara";
         s.Age = 9;
         Console.WriteLine("Student Info:- {0}", s);
         
         //let us increase age
         s.Age += 1;
         Console.WriteLine("Student Info:- {0}", s);
         Console.ReadKey();
      }
   }
}

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

Student Info: Code = 001, Name = Zara, Age = 9
Student Info: Code = 001, Name = Zara, Age = 10

एक indexerकिसी ऑब्जेक्ट को एक सरणी जैसे अनुक्रमित करने की अनुमति देता है। जब आप किसी वर्ग के लिए एक अनुक्रमणिका को परिभाषित करते हैं, तो यह वर्ग एक के समान व्यवहार करता हैvirtual array। फिर आप ऐरे एक्सेस ऑपरेटर ([]) का उपयोग करके इस वर्ग के उदाहरण तक पहुँच सकते हैं।

वाक्य - विन्यास

एक आयामी अनुक्रमणिका में निम्नलिखित सिंटैक्स होता है -

element-type this[int index] {

   // The get accessor.
   get {
      // return the value specified by index
   }
   
   // The set accessor.
   set {
      // set the value specified by index
   }
}

इंडेक्सर्स का उपयोग

एक अनुक्रमणिका के व्यवहार की घोषणा संपत्ति के समान कुछ हद तक है। गुणों के समान, आप उपयोग करते हैं get तथा setअनुक्रमणिका को परिभाषित करने के लिए अभिगमकर्ता। हालाँकि, गुण विशिष्ट डेटा सदस्य को लौटाते हैं या सेट करते हैं, जबकि अनुक्रमणिका ऑब्जेक्ट उदाहरण से एक विशेष मान लौटाती है या सेट करती है। दूसरे शब्दों में, यह उदाहरण डेटा को छोटे भागों में तोड़ता है और प्रत्येक भाग को अनुक्रमित करता है, प्रत्येक भाग को प्राप्त या सेट करता है।

एक संपत्ति को परिभाषित करने में एक संपत्ति नाम प्रदान करना शामिल है। इंडेक्सर्स को नामों से परिभाषित नहीं किया जाता है, लेकिन इसके साथthisकीवर्ड, जो ऑब्जेक्ट इंस्टेंस को संदर्भित करता है। निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है -

using System;

namespace IndexerApplication {
   
   class IndexedNames {
      private string[] namelist = new string[size];
      static public int size = 10;
      
      public IndexedNames() {
         for (int i = 0; i < size; i++)
         namelist[i] = "N. A.";
      }
      
      public string this[int index] {
      
         get {
            string tmp;
         
            if( index >= 0 && index <= size-1 ) {
               tmp = namelist[index];
            } else {
               tmp = "";
            }
            
            return ( tmp );
         }
         set {
            if( index >= 0 && index <= size-1 ) {
               namelist[index] = value;
            }
         }
      }
      
      static void Main(string[] args) {
         IndexedNames names = new IndexedNames();
         names[0] = "Zara";
         names[1] = "Riz";
         names[2] = "Nuha";
         names[3] = "Asif";
         names[4] = "Davinder";
         names[5] = "Sunil";
         names[6] = "Rubic";
         
         for ( int i = 0; i < IndexedNames.size; i++ ) {
            Console.WriteLine(names[i]);
         }
         Console.ReadKey();
      }
   }
}

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

Zara
Riz
Nuha
Asif
Davinder
Sunil
Rubic
N. A.
N. A.
N. A.

ओवरलोडेड इंडेक्सर्स

इंडेक्सर्स को ओवरलोड किया जा सकता है। इंडेक्सर्स को कई मापदंडों के साथ भी घोषित किया जा सकता है और प्रत्येक पैरामीटर एक अलग प्रकार का हो सकता है। यह आवश्यक नहीं है कि अनुक्रमणिका को पूर्णांक होना चाहिए। C # अनुक्रमणिका को अन्य प्रकार के होने की अनुमति देता है, उदाहरण के लिए, एक स्ट्रिंग।

निम्न उदाहरण अतिभारित सूचकांक प्रदर्शित करता है -

using System;

namespace IndexerApplication {

   class IndexedNames {
      private string[] namelist = new string[size];
      static public int size = 10;
      
      public IndexedNames() {
         for (int i = 0; i < size; i++) {
            namelist[i] = "N. A.";
         }
      }
      
      public string this[int index] {
         
         get {
            string tmp;
            
            if( index >= 0 && index <= size-1 ) {
               tmp = namelist[index];
            } else {
               tmp = "";
            }
            
            return ( tmp );
         }
         set {
            if( index >= 0 && index <= size-1 ) {
               namelist[index] = value;
            }
         }
      }
      
      public int this[string name] {
         
         get {
            int index = 0;
            
            while(index < size) {
               if (namelist[index] == name) {
                return index;
               }
               index++;
            }
            return index;
         }

      }

      static void Main(string[] args) {
         IndexedNames names = new IndexedNames();
         names[0] = "Zara";
         names[1] = "Riz";
         names[2] = "Nuha";
         names[3] = "Asif";
         names[4] = "Davinder";
         names[5] = "Sunil";
         names[6] = "Rubic";
         
         //using the first indexer with int parameter
         for (int i = 0; i < IndexedNames.size; i++) {
            Console.WriteLine(names[i]);
         }
         
         //using the second indexer with the string parameter
         Console.WriteLine(names["Nuha"]);
         Console.ReadKey();
      }
   }
}

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

Zara
Riz
Nuha
Asif
Davinder
Sunil
Rubic
N. A.
N. A.
N. A.
2

C # डेलीगेट C या C ++ में, फंक्शन के पॉइंटर्स के समान हैं। एdelegateएक संदर्भ प्रकार चर है जो एक विधि के संदर्भ को रखता है। संदर्भ को रनटाइम में बदला जा सकता है।

प्रतिनिधि विशेष रूप से घटनाओं और कॉल-बैक विधियों को लागू करने के लिए उपयोग किया जाता है। सभी प्रतिनिधियों को अंतर्निहित रूप से व्युत्पन्न किया जाता हैSystem.Delegate कक्षा।

घोषणा पत्र

डेलिगेट घोषणा प्रतिनिधि द्वारा संदर्भित तरीकों को निर्धारित करती है। एक प्रतिनिधि एक विधि का उल्लेख कर सकता है, जिसमें प्रतिनिधि के रूप में एक ही हस्ताक्षर हो।

उदाहरण के लिए, एक प्रतिनिधि पर विचार करें -

public delegate int MyDelegate (string s);

पूर्ववर्ती प्रतिनिधि का उपयोग किसी भी विधि को संदर्भित करने के लिए किया जा सकता है जिसमें एकल स्ट्रिंग पैरामीटर होता है और एक इंट प्रकार चर देता है।

प्रतिनिधि घोषणा के लिए सिंटैक्स है -

delegate <return type> <delegate-name> <parameter list>

तात्कालिक प्रतिनिधि

एक बार एक प्रतिनिधि प्रकार घोषित होने के बाद, एक प्रतिनिधि वस्तु के साथ बनाया जाना चाहिए new कीवर्ड और एक विशेष विधि के साथ जुड़ा हुआ है। एक प्रतिनिधि बनाते समय, तर्क पास किया गयाnewअभिव्यक्ति को विधि कॉल के समान लिखा जाता है, लेकिन विधि के तर्कों के बिना। उदाहरण के लिए -

public delegate void printString(string s);
...
printString ps1 = new printString(WriteToScreen);
printString ps2 = new printString(WriteToFile);

उदाहरण के बाद घोषणा, तात्कालिकता और एक प्रतिनिधि के उपयोग को दर्शाता है जिसका उपयोग उन संदर्भ विधियों के लिए किया जा सकता है जो पूर्णांक पैरामीटर लेते हैं और पूर्णांक मान लौटाते हैं।

using System;

delegate int NumberChanger(int n);
namespace DelegateAppl {
   
   class TestDelegate {
      static int num = 10;
      
      public static int AddNum(int p) {
         num += p;
         return num;
      }

      public static int MultNum(int q) {
         num *= q;
         return num;
      }
      
      public static int getNum() {
         return num;
      }

      static void Main(string[] args) {
         //create delegate instances
         NumberChanger nc1 = new NumberChanger(AddNum);
         NumberChanger nc2 = new NumberChanger(MultNum);
         
         //calling the methods using the delegate objects
         nc1(25);
         Console.WriteLine("Value of Num: {0}", getNum());
         nc2(5);
         Console.WriteLine("Value of Num: {0}", getNum());
         Console.ReadKey();
      }
   }
}

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

Value of Num: 35
Value of Num: 175

एक प्रतिनिधि के बहुरंगी

प्रतिनिधि ऑब्जेक्ट "+" ऑपरेटर का उपयोग करके बनाया जा सकता है। एक रचित प्रतिनिधि दो प्रतिनिधियों को बुलाता है जिनसे यह रचा गया था। केवल उसी प्रकार के प्रतिनिधियों की रचना की जा सकती है। "-" ऑपरेटर का उपयोग कंपोजिट डेलिगेट के कंपोनेंट डेलिगेट को हटाने के लिए किया जा सकता है।

प्रतिनिधियों की इस संपत्ति का उपयोग करके आप उन विधियों की एक आह्वान सूची बना सकते हैं, जिन्हें किसी प्रतिनिधि को आमंत्रित किए जाने पर बुलाया जाएगा। यह कहा जाता हैmulticastingएक प्रतिनिधि के। निम्नलिखित कार्यक्रम एक प्रतिनिधि के बहुरंगी प्रदर्शन -

using System;

delegate int NumberChanger(int n);
namespace DelegateAppl {

   class TestDelegate {
      static int num = 10;
      
      public static int AddNum(int p) {
         num += p;
         return num;
      }

      public static int MultNum(int q) {
         num *= q;
         return num;
      }
      
      public static int getNum() {
         return num;
      }

      static void Main(string[] args) {
         //create delegate instances
         NumberChanger nc;
         NumberChanger nc1 = new NumberChanger(AddNum);
         NumberChanger nc2 = new NumberChanger(MultNum);
         nc = nc1;
         nc += nc2;
         
         //calling multicast
         nc(5);
         Console.WriteLine("Value of Num: {0}", getNum());
         Console.ReadKey();
      }
   }
}

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

Value of Num: 75

डेलिगेट्स का उपयोग करना

निम्न उदाहरण प्रतिनिधि के उपयोग को दर्शाता है। डेलिगेट प्रिंटस्ट्रिंग का उपयोग संदर्भ विधि के लिए किया जा सकता है जो इनपुट के रूप में एक स्ट्रिंग लेता है और कुछ भी नहीं देता है।

हम दो तरीकों को कॉल करने के लिए इस प्रतिनिधि का उपयोग करते हैं, पहला स्ट्रिंग को कंसोल पर प्रिंट करता है, और दूसरा एक फाइल में प्रिंट करता है -

using System;
using System.IO;

namespace DelegateAppl {

   class PrintString {
      static FileStream fs;
      static StreamWriter sw;
      
      // delegate declaration
      public delegate void printString(string s);

      // this method prints to the console
      public static void WriteToScreen(string str) {
         Console.WriteLine("The String is: {0}", str);
      }
      
      //this method prints to a file
      public static void WriteToFile(string s) {
         fs = new FileStream("c:\\message.txt",
         FileMode.Append, FileAccess.Write);
         sw = new StreamWriter(fs);
         sw.WriteLine(s);
         sw.Flush();
         sw.Close();
         fs.Close();
      }
      
      // this method takes the delegate as parameter and uses it to
      // call the methods as required
      public static void sendString(printString ps) {
         ps("Hello World");
      }
      
      static void Main(string[] args) {
         printString ps1 = new printString(WriteToScreen);
         printString ps2 = new printString(WriteToFile);
         sendString(ps1);
         sendString(ps2);
         Console.ReadKey();
      }
   }
}

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

The String is: Hello World

Eventsउपयोगकर्ता की गतिविधियाँ जैसे की प्रेस, क्लिक, माउस मूवमेंट इत्यादि, या कुछ घटनाएँ जैसे सिस्टम जनरेटेड नोटिफिकेशन। एप्लिकेशन को होने वाली घटनाओं पर प्रतिक्रिया देने की आवश्यकता होती है। उदाहरण के लिए, व्यवधान। घटनाओं का उपयोग अंतर-प्रक्रिया संचार के लिए किया जाता है।

इवेंट्स के साथ डेलिगेट्स का उपयोग करना

घटनाओं को घोषित किया जाता है और एक कक्षा में उठाया जाता है और एक ही वर्ग या किसी अन्य वर्ग के प्रतिनिधियों के साथ घटना संचालकों से जुड़ा होता है। ईवेंट युक्त क्लास का उपयोग ईवेंट प्रकाशित करने के लिए किया जाता है। इसे कहते हैंpublisherकक्षा। इस घटना को स्वीकार करने वाले कुछ अन्य वर्ग को कहा जाता हैsubscriber कक्षा। घटनाओं का उपयोग करेंpublisher-subscriber नमूना।

publisherएक ऐसी वस्तु है जिसमें घटना की परिभाषा और प्रतिनिधि शामिल हैं। इवेंट-डेलीगेट एसोसिएशन को भी इस ऑब्जेक्ट में परिभाषित किया गया है। एक प्रकाशक वर्ग ऑब्जेक्ट घटना को आमंत्रित करता है और इसे अन्य वस्तुओं के लिए अधिसूचित किया जाता है।

subscriberएक ऐसी वस्तु है जो घटना को स्वीकार करती है और एक घटना हैंडलर प्रदान करती है। प्रकाशक वर्ग में प्रतिनिधि ग्राहक वर्ग की विधि (घटना संचालक) को आमंत्रित करता है।

घटनाओं की घोषणा

किसी वर्ग के अंदर एक घटना की घोषणा करने के लिए, सबसे पहले, आपको एक प्रतिनिधि प्रकार की घोषणा करनी चाहिए:

public delegate string BoilerLogHandler(string str);

फिर, ईवेंट के उपयोग की घोषणा करें event कीवर्ड -

event BoilerLogHandler BoilerEventLog;

पूर्ववर्ती कोड एक प्रतिनिधि नामित को परिभाषित करता है BoilerLogHandler और एक घटना नामित BoilerEventLog , जो प्रतिनिधि का आह्वान जब यह बढ़ जाता है।

उदाहरण

using System;

namespace SampleApp {
   public delegate string MyDel(string str);
	
   class EventProgram {
      event MyDel MyEvent;
		
      public EventProgram() {
         this.MyEvent += new MyDel(this.WelcomeUser);
      }
		
      public string WelcomeUser(string username) {
         return "Welcome " + username;
      }
		
      static void Main(string[] args) {
         EventProgram obj1 = new EventProgram();
         string result = obj1.MyEvent("Tutorials Point");
         Console.WriteLine(result);
      }

   }
}

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

Welcome Tutorials Point

संग्रह कक्षाएं डेटा भंडारण और पुनर्प्राप्ति के लिए विशेष कक्षाएं हैं। ये कक्षाएं स्टैक, कतारों, सूचियों और हैश टेबल के लिए सहायता प्रदान करती हैं। अधिकांश संग्रह कक्षाएं समान इंटरफेस को लागू करती हैं।

संग्रह कक्षाएं विभिन्न उद्देश्यों की पूर्ति करती हैं, जैसे तत्वों को गतिशील रूप से मेमोरी आवंटित करना और किसी सूचकांक के आधार पर वस्तुओं की सूची तक पहुंच आदि। ये कक्षाएं ऑब्जेक्ट क्लास की वस्तुओं का संग्रह बनाती हैं, जो C # में सभी डेटा प्रकारों के लिए आधार वर्ग है।

विभिन्न संग्रह कक्षाएं और उनके उपयोग

निम्नलिखित सामान्य रूप से उपयोग किए जाने वाले विभिन्न वर्ग हैं System.Collectionनाम स्थान। उनके विवरण की जाँच करने के लिए निम्न लिंक पर क्लिक करें।

अनु क्रमांक। वर्ग और विवरण और उपयोग
1 सारणी सूची

यह एक वस्तु के आदेशित संग्रह का प्रतिनिधित्व करता है जो हो सकता है indexed व्यक्तिगत रूप से।

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

2 हैश टेबल

यह एक का उपयोग करता है key संग्रह में तत्वों तक पहुँचने के लिए।

एक हैश तालिका का उपयोग तब किया जाता है जब आपको कुंजी का उपयोग करके तत्वों तक पहुंचने की आवश्यकता होती है, और आप एक उपयोगी कुंजी मान की पहचान कर सकते हैं। हैश तालिका में प्रत्येक आइटम एक हैkey/valueजोड़ी। संग्रह में आइटम तक पहुंचने के लिए कुंजी का उपयोग किया जाता है।

3 SortedList

यह एक का उपयोग करता है key साथ ही ए index एक सूची में आइटम तक पहुँचने के लिए।

एक क्रमबद्ध सूची एक सरणी और हैश तालिका का एक संयोजन है। इसमें उन वस्तुओं की एक सूची शामिल है, जिन्हें कुंजी या इंडेक्स का उपयोग करके एक्सेस किया जा सकता है। यदि आप किसी इंडेक्स का उपयोग करके आइटम एक्सेस करते हैं, तो यह एक ArrayList है, और यदि आप किसी कुंजी का उपयोग करके आइटम एक्सेस करते हैं, तो यह एक हैशटेबल है। वस्तुओं का संग्रह हमेशा कुंजी मूल्य द्वारा क्रमबद्ध होता है।

4 ढेर

यह एक का प्रतिनिधित्व करता है last-in, first out वस्तु का संग्रह।

इसका उपयोग तब किया जाता है जब आपको अंतिम-इन, पहले-आउट आइटम की आवश्यकता होती है। जब आप सूची में कोई आइटम जोड़ते हैं, तो उसे कहा जाता हैpushing आइटम और जब आप इसे हटाते हैं, तो इसे कहा जाता है popping मद # जिंस।

5 कतार

यह एक का प्रतिनिधित्व करता है first-in, first out वस्तु का संग्रह।

इसका उपयोग तब किया जाता है जब आपको वस्तुओं की पहली-इन, पहली-आउट पहुंच की आवश्यकता होती है। जब आप सूची में कोई आइटम जोड़ते हैं, तो उसे कहा जाता हैenqueue और जब आप किसी आइटम को हटाते हैं, तो उसे कहा जाता है deque

6 BitArray

यह एक सरणी का प्रतिनिधित्व करता है binary representation 1 और 0 के मान का उपयोग करते हुए।

इसका उपयोग तब किया जाता है जब आपको बिट्स को स्टोर करने की आवश्यकता होती है, लेकिन बिट्स की संख्या को पहले से पता नहीं होता है। आप एक का उपयोग करके BitArray संग्रह से आइटम का उपयोग कर सकते हैंinteger index, जो शून्य से शुरू होता है।

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

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

using System;
using System.Collections.Generic;

namespace GenericApplication {

   public class MyGenericArray<T> {
      private T[] array;
      
      public MyGenericArray(int size) {
         array = new T[size + 1];
      }
      
      public T getItem(int index) {
         return array[index];
      }
      
      public void setItem(int index, T value) {
         array[index] = value;
      }
   }
   
   class Tester {
      static void Main(string[] args) {
         
         //declaring an int array
         MyGenericArray<int> intArray = new MyGenericArray<int>(5);
         
         //setting values
         for (int c = 0; c < 5; c++) {
            intArray.setItem(c, c*5);
         }
         
         //retrieving the values
         for (int c = 0; c < 5; c++) {
            Console.Write(intArray.getItem(c) + " ");
         }
         
         Console.WriteLine();
         
         //declaring a character array
         MyGenericArray<char> charArray = new MyGenericArray<char>(5);
         
         //setting values
         for (int c = 0; c < 5; c++) {
            charArray.setItem(c, (char)(c+97));
         }
         
         //retrieving the values
         for (int c = 0; c< 5; c++) {
            Console.Write(charArray.getItem(c) + " ");
         }
         Console.WriteLine();
         
         Console.ReadKey();
      }
   }
}

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

0 5 10 15 20
a b c d e

जेनरिक की विशेषताएं

जेनरिक एक ऐसी तकनीक है जो आपके कार्यक्रमों को निम्नलिखित तरीकों से समृद्ध करती है -

  • यह कोड का पुन: उपयोग, सुरक्षा और प्रदर्शन को अधिकतम करने में आपकी सहायता करता है।

  • आप सामान्य संग्रह कक्षाएं बना सकते हैं। .NET फ्रेमवर्क वर्ग की लाइब्रेरी में System.Collections.Generic नाम स्थान में कई नए सामान्य संग्रह कक्षाएं हैं । आप System.Collections नामस्थान में संग्रह कक्षाओं के बजाय इन सामान्य संग्रह कक्षाओं का उपयोग कर सकते हैं ।

  • आप अपने स्वयं के सामान्य इंटरफेस, कक्षाएं, विधियों, घटनाओं और प्रतिनिधियों को बना सकते हैं।

  • आप विशेष डेटा प्रकारों के तरीकों तक पहुंच को सक्षम करने के लिए सामान्य वर्ग को विवश कर सकते हैं।

  • आप एक सामान्य डेटा प्रकार में उपयोग किए जाने वाले प्रकारों की जानकारी रन-टाइम पर प्रतिबिंब के माध्यम से प्राप्त कर सकते हैं।

सामान्य तरीके

पिछले उदाहरण में, हमने एक सामान्य वर्ग का उपयोग किया है; हम एक प्रकार के पैरामीटर के साथ एक सामान्य विधि घोषित कर सकते हैं। निम्नलिखित कार्यक्रम अवधारणा को दर्शाता है -

using System;
using System.Collections.Generic;

namespace GenericMethodAppl {
   
   class Program {
      
      static void Swap<T>(ref T lhs, ref T rhs) {
         T temp;
         temp = lhs;
         lhs = rhs;
         rhs = temp;
      }
      
      static void Main(string[] args) {
         int a, b;
         char c, d;
         a = 10;
         b = 20;
         c = 'I';
         d = 'V';
         
         //display values before swap:
         Console.WriteLine("Int values before calling swap:");
         Console.WriteLine("a = {0}, b = {1}", a, b);
         Console.WriteLine("Char values before calling swap:");
         Console.WriteLine("c = {0}, d = {1}", c, d);
         
         //call swap
         Swap<int>(ref a, ref b);
         Swap<char>(ref c, ref d);
         
         //display values after swap:
         Console.WriteLine("Int values after calling swap:");
         Console.WriteLine("a = {0}, b = {1}", a, b);
         Console.WriteLine("Char values after calling swap:");
         Console.WriteLine("c = {0}, d = {1}", c, d);
         
         Console.ReadKey();
      }
   }
}

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

Int values before calling swap:
a = 10, b = 20
Char values before calling swap:
c = I, d = V
Int values after calling swap:
a = 20, b = 10
Char values after calling swap:
c = V, d = I

जेनेरिक डेलीगेट्स

आप प्रकार के मापदंडों के साथ एक सामान्य प्रतिनिधि को परिभाषित कर सकते हैं। उदाहरण के लिए -

delegate T NumberChanger<T>(T n);

निम्नलिखित उदाहरण इस प्रतिनिधि का उपयोग दिखाता है -

using System;
using System.Collections.Generic;

delegate T NumberChanger<T>(T n);
namespace GenericDelegateAppl {
   
   class TestDelegate {
      static int num = 10;
      
      public static int AddNum(int p) {
         num += p;
         return num;
      }
      
      public static int MultNum(int q) {
         num *= q;
         return num;
      }
      
      public static int getNum() {
         return num;
      }
      
      static void Main(string[] args) {
         //create delegate instances
         NumberChanger<int> nc1 = new NumberChanger<int>(AddNum);
         NumberChanger<int> nc2 = new NumberChanger<int>(MultNum);
         
         //calling the methods using the delegate objects
         nc1(25);
         Console.WriteLine("Value of Num: {0}", getNum());
         nc2(5);
         Console.WriteLine("Value of Num: {0}", getNum());
         Console.ReadKey();
      }
   }
}

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

Value of Num: 35
Value of Num: 175

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

Anonymous methodsएक प्रतिनिधि ब्लॉक के रूप में एक कोड ब्लॉक पास करने के लिए एक तकनीक प्रदान करें। अनाम विधियाँ एक नाम के बिना केवल शरीर की विधियाँ हैं।

आपको अनाम विधि में रिटर्न प्रकार निर्दिष्ट करने की आवश्यकता नहीं है; यह विधि निकाय के अंदर रिटर्न स्टेटमेंट से अनुमानित है।

अनाम विधि लिखना

अनाम विधियों को प्रतिनिधि उदाहरण के निर्माण के साथ घोषित किया जाता है, ए के साथ delegateकीवर्ड। उदाहरण के लिए,

delegate void NumberChanger(int n);
...
NumberChanger nc = delegate(int x) {
   Console.WriteLine("Anonymous Method: {0}", x);
};

कोड ब्लॉक Console.WriteLine ("बेनामी विधि: {0}", x); अनाम विधि का शरीर है।

प्रतिनिधि को अनाम विधियों के साथ-साथ नामित तरीकों से दोनों को बुलाया जा सकता है, अर्थात प्रतिनिधि पैरामीटर विधि के मापदंडों को पारित करके।

उदाहरण के लिए,

nc(10);

उदाहरण

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

using System;

delegate void NumberChanger(int n);
namespace DelegateAppl {
   
   class TestDelegate {
      static int num = 10;
      
      public static void AddNum(int p) {
         num += p;
         Console.WriteLine("Named Method: {0}", num);
      }
      
      public static void MultNum(int q) {
         num *= q;
         Console.WriteLine("Named Method: {0}", num);
      }
      
      public static int getNum() {
         return num;
      }
      
      static void Main(string[] args) {
         //create delegate instances using anonymous method
         NumberChanger nc = delegate(int x) {
            Console.WriteLine("Anonymous Method: {0}", x);
         };
         
         //calling the delegate using the anonymous method 
         nc(10);
         
         //instantiating the delegate using the named methods 
         nc =  new NumberChanger(AddNum);
         
         //calling the delegate using the named methods 
         nc(5);
         
         //instantiating the delegate using another named methods 
         nc =  new NumberChanger(MultNum);
         
         //calling the delegate using the named methods 
         nc(2);
         Console.ReadKey();
      }
   }
}

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

Anonymous Method: 10
Named Method: 15
Named Method: 30

सी # ब्लॉक कोड के एक फ़ंक्शन में पॉइंटर चर का उपयोग करने की अनुमति देता है जब इसे चिह्नित किया जाता है unsafeसंशोधक। unsafe code या मानवरहित कोड एक कोड ब्लॉक है जो एक का उपयोग करता है pointer चर।

Note- कोडिंग ग्राउंड में इस अध्याय में वर्णित कार्यक्रमों को निष्पादित करने के लिए , कृपया प्रोजेक्ट में संकलन विकल्प सेट करें >> संकलन विकल्प >> संकलन कमांड टू

mcs *.cs -out:main.exe -unsafe"

संकेत

pointerएक वैरिएबल जिसका मान किसी अन्य वैरिएबल का पता है यानी मेमोरी लोकेशन का सीधा पता। किसी भी चर या स्थिर के समान, आपको किसी भी चर पते को संग्रहीत करने के लिए इसका उपयोग करने से पहले एक सूचक घोषित करना होगा।

सूचक घोषणा का सामान्य रूप है -

type *var-name;

मान्य सूचक घोषणाएँ निम्नलिखित हैं -

int    *ip;    /* pointer to an integer */
double *dp;    /* pointer to a double */
float  *fp;    /* pointer to a float */
char   *ch     /* pointer to a character */

निम्नलिखित उदाहरण सी # में संकेत के उपयोग को दिखाता है, असुरक्षित संशोधक का उपयोग करते हुए -

using System;

namespace UnsafeCodeApplication {
   
   class Program {
      
      static unsafe void Main(string[] args) {
         int var = 20;
         int* p = &var;
         Console.WriteLine("Data is: {0} ",  var);
         Console.WriteLine("Address is: {0}",  (int)p);
         Console.ReadKey();
      }
   }
}

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

Data is: 20
Address is: 99215364

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

एक पॉइंटर का उपयोग करके डेटा मान को पुनः प्राप्त करना

आप पॉइंटर चर द्वारा संदर्भित डेटा पर संग्रहीत डेटा को पुनः प्राप्त कर सकते हैं, का उपयोग करके ToString()तरीका। निम्न उदाहरण यह प्रदर्शित करता है -

using System;

namespace UnsafeCodeApplication {
   
   class Program {
      
      public static void Main() {
         
         unsafe {
            int var = 20;
            int* p = &var;
            Console.WriteLine("Data is: {0} " , var);
            Console.WriteLine("Data is: {0} " , p->ToString());
            Console.WriteLine("Address is: {0} " , (int)p);
         }
         
         Console.ReadKey();
      }
   }
}

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

Data is: 20
Data is: 20
Address is: 77128984

विधियों के पैरामीटर के रूप में पासिंग पॉइंटर्स

आप पैरामीटर के रूप में एक पॉइंटर चर को विधि के रूप में पास कर सकते हैं। निम्न उदाहरण यह दिखाता है -

using System;

namespace UnsafeCodeApplication {
   
   class TestPointer {
      
      public unsafe void swap(int* p, int *q) {
         int temp = *p;
         *p = *q;
         *q = temp;
      }
      
      public unsafe static void Main() {
         TestPointer p = new TestPointer();
         int var1 = 10;
         int var2 = 20;
         int* x = &var1;
         int* y = &var2;
         
         Console.WriteLine("Before Swap: var1:{0}, var2: {1}", var1, var2);
         p.swap(x, y);

         Console.WriteLine("After Swap: var1:{0}, var2: {1}", var1, var2);
         Console.ReadKey();
      }
   }
}

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

Before Swap: var1: 10, var2: 20
After Swap: var1: 20, var2: 10

पॉइंटर का उपयोग करके ऐरे तत्वों को एक्सेस करना

C # में, एक सरणी नाम और डेटा प्रकार के लिए एक संकेतक, जो सरणी डेटा के समान है, समान चर प्रकार नहीं हैं। उदाहरण के लिए, int * p और int [] p, एक ही प्रकार के नहीं हैं। आप पॉइंटर वैरिएबल पी को बढ़ा सकते हैं क्योंकि यह मेमोरी में तय नहीं किया गया है, लेकिन मेमोरी में एक सरणी पता तय है, और आप इसे नहीं बढ़ा सकते।

इसलिए, यदि आपको पॉइंटर चर का उपयोग करके एक सरणी डेटा तक पहुंचने की आवश्यकता है, जैसा कि हम पारंपरिक रूप से C, या C ++ (कृपया जाँच करें: C पॉइंटर्स ) में करते हैं, तो आपको सूचक का उपयोग करके ठीक करने की आवश्यकता हैfixed कीवर्ड।

निम्न उदाहरण यह प्रदर्शित करता है -

using System;

namespace UnsafeCodeApplication {
   
   class TestPointer {
      
      public unsafe static void Main() {
         int[]  list = {10, 100, 200};
         fixed(int *ptr = list)
         
         /* let us have array address in pointer */
         for ( int i = 0; i < 3; i++) {
            Console.WriteLine("Address of list[{0}]={1}",i,(int)(ptr + i));
            Console.WriteLine("Value of list[{0}]={1}", i, *(ptr + i));
         }
         
         Console.ReadKey();
      }
   }
}

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

Address of list[0] = 31627168
Value of list[0] = 10
Address of list[1] = 31627172
Value of list[1] = 100
Address of list[2] = 31627176
Value of list[2] = 200

संकलन कोड असुरक्षित

असुरक्षित कोड संकलित करने के लिए, आपको निर्दिष्ट करना होगा /unsafe कमांड-लाइन स्विच कमांड-लाइन कंपाइलर के साथ।

उदाहरण के लिए, कमांड लाइन से असुरक्षित कोड वाले prog1.cs नामक प्रोग्राम को संकलित करने के लिए, कमांड दें -

csc /unsafe prog1.cs

यदि आप Visual Studio IDE का उपयोग कर रहे हैं, तो आपको प्रोजेक्ट गुणों में असुरक्षित कोड का उपयोग करने की आवश्यकता है।

ऐसा करने के लिए -

  • खुला हुआ project properties समाधान एक्सप्लोरर में गुण नोड पर डबल क्लिक करके।

  • पर क्लिक करें Build टैब।

  • विकल्प चुनेंAllow unsafe code"।

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