.NET कोर - क्विक गाइड
.NET कोर Microsoft द्वारा बनाए रखा गया नवीनतम सामान्य प्रयोजन विकास मंच है। यह विभिन्न प्लेटफार्मों पर काम करता है और इसे इस तरह से नया रूप दिया गया है जो .NET को तेज, लचीला और आधुनिक बनाता है। यह Microsoft के प्रमुख योगदानों में से एक है। डेवलपर्स अब .NET, Android, iOS, Mac, और Windows अनुप्रयोगों को .NET, सभी ओपन सोर्स में बना सकते हैं।
इस ट्यूटोरियल में, हम .NET कोर और कुछ नए इनोवेशन शामिल करेंगे, जिनमें .NET फ्रेमवर्क अपडेट, .NET स्टैंडर्ड और यूनिवर्सल विंडोज प्लेटफॉर्म अपडेट आदि शामिल हैं।
.NET कोर के लक्षण
.NET कोर की प्रमुख विशेषताएं निम्नलिखित हैं -
खुला स्त्रोत
.NET कोर MIT और Apache 2 लाइसेंस का उपयोग करते हुए एक खुला स्रोत कार्यान्वयन है।
.NET कोर एक .NET फाउंडेशन प्रोजेक्ट है और GitHub पर उपलब्ध है।
एक ओपन सोर्स प्रोजेक्ट के रूप में, यह अधिक पारदर्शी विकास प्रक्रिया को बढ़ावा देता है और एक सक्रिय और लगे हुए समुदाय को बढ़ावा देता है।
क्रॉस-प्लेटफॉर्म
.NET कोर में लागू किया गया एप्लिकेशन चलाया जा सकता है और इसका कोड आपके प्लेटफ़ॉर्म लक्ष्य की परवाह किए बिना पुन: उपयोग किया जा सकता है।
यह वर्तमान में तीन मुख्य ऑपरेटिंग सिस्टम (OS) का समर्थन करता है
Windows
Linux
MacOS
समर्थित ऑपरेटिंग सिस्टम (OS), CPU और एप्लिकेशन परिदृश्य समय के साथ बढ़ेंगे, Microsoft, अन्य कंपनियों और व्यक्तियों द्वारा प्रदान किए जाएंगे।
लचीली तैनाती
.NET कोर अनुप्रयोगों के लिए दो प्रकार की तैनाती हो सकती है -
फ्रेमवर्क पर निर्भर तैनाती
स्वयं की तैनाती
फ्रेमवर्क-निर्भर परिनियोजन के साथ, आपका ऐप .NET कोर के एक सिस्टम-वाइड संस्करण पर निर्भर करता है, जिस पर आपका ऐप और थर्ड-पार्टी निर्भरताएं स्थापित हैं।
स्व-निहित परिनियोजन के साथ, आपके अनुप्रयोग को बनाने के लिए उपयोग किया जाने वाला .NET कोर संस्करण भी आपके ऐप और तृतीय-पक्ष निर्भरता के साथ तैनात किया गया है और अन्य संस्करणों के साथ-साथ-साथ चल सकता है।
कमांड लाइन उपकरण
सभी उत्पाद परिदृश्यों को कमांड-लाइन पर प्रयोग किया जा सकता है।
संगत
.NET मानक लाइब्रेरी के माध्यम से .NET कोर .NET फ्रेमवर्क, ज़ामरीन और मोनो के साथ संगत है
मॉड्यूलर
.NET कोर को छोटे असेंबली पैकेज में NuGet के माध्यम से जारी किया जाता है।
.NET फ्रेमवर्क एक बड़ी असेंबली है जिसमें ज्यादातर कोर फंक्शंस होते हैं।
.NET कोर को छोटे फीचर-केंद्रित पैकेज के रूप में उपलब्ध कराया गया है।
यह मॉड्यूलर दृष्टिकोण डेवलपर्स को केवल उन NuGet पैकेजों को शामिल करके अपने ऐप का अनुकूलन करने में सक्षम बनाता है, जिनकी उन्हें अपने ऐप में आवश्यकता होती है।
एक छोटे ऐप सतह क्षेत्र के लाभों में तंग सुरक्षा, कम सर्विसिंग, बेहतर प्रदर्शन और भुगतान-में-क्या-आप उपयोग मॉडल के लिए लागत में कमी शामिल है।
.NET कोर प्लेटफॉर्म
.NET कोर प्लेटफॉर्म में निम्नलिखित मुख्य भाग शामिल हैं -
.NET Runtime - यह एक प्रकार की प्रणाली, असेंबली लोडिंग, एक कचरा कलेक्टर, देशी इंटरॉप और अन्य बुनियादी सेवाएं प्रदान करता है।
Fundamental Libraries - ढांचा पुस्तकालयों का एक सेट, जो आदिम डेटा प्रकार, एप्लिकेशन संरचना प्रकार और मौलिक उपयोगिताओं प्रदान करता है।
SDK & Compiler - SDK टूल और भाषा संकलक का एक सेट जो .NET डेवलपर SDK में उपलब्ध आधार डेवलपर अनुभव को सक्षम करता है।
‘dotnet’ app host- इसका इस्तेमाल .NET Core ऐप लॉन्च करने के लिए किया जाता है। यह रनटाइम का चयन करता है और रनटाइम को होस्ट करता है, एक असेंबली लोडिंग नीति प्रदान करता है और ऐप लॉन्च करता है। उसी होस्ट का उपयोग एसडीके टूल्स को उसी तरह से लॉन्च करने के लिए भी किया जाता है।
इस अध्याय में, हम उन विभिन्न निर्भरताओं पर चर्चा करेंगे जिन्हें आपको तैनात करने और चलाने की आवश्यकता है। इनमें Visual Studio का उपयोग करके विकसित की गई Windows मशीनों पर .NET कोर एप्लिकेशन शामिल हैं।
समर्थित Windows संस्करण
.NET कोर विंडोज के निम्नलिखित संस्करणों पर समर्थित है -
- विंडोज 7 SP1
- विंडोज 8.1
- विंडोज 10
- Windows Server 2008 R2 SP1 (पूर्ण सर्वर या सर्वर कोर)
- Windows Server 2012 SP1 (पूर्ण सर्वर या सर्वर कोर)
- Windows सर्वर 2012 R2 SP1 (पूर्ण सर्वर या सर्वर कोर)
- विंडोज सर्वर 2016 (पूर्ण सर्वर, सर्वर कोर या नैनो सर्वर)
निर्भरता
यदि आप विंडोज 10 और विंडोज सर्वर 2016 की तुलना में विंडोज संस्करणों पर अपने .NET कोर एप्लिकेशन को चला रहे हैं, तो इसके लिए विजुअल C ++ रिडिजाइनेबल की भी आवश्यकता होगी।
यदि आप .NET कोर इंस्टॉलर का उपयोग करते हैं तो यह निर्भरता आपके लिए स्वचालित रूप से स्थापित हो जाती है।
यदि आप .NET स्क्रिप्ट को इंस्टॉलर स्क्रिप्ट के माध्यम से स्थापित कर रहे हैं या स्व-निहित .NET कोर एप्लिकेशन को तैनात कर रहे हैं, तो आपको Visual C ++ Redistributable को मैन्युअल रूप से इंस्टॉल करने की आवश्यकता है।
विंडोज 7 और विंडोज सर्वर 2008 मशीनों के लिए, आपको यह सुनिश्चित करने की आवश्यकता है कि आपकी विंडोज स्थापना अद्यतित है और इसमें विंडोज अपडेट के माध्यम से स्थापित किया गया हॉटफ़िक्स KB2533623 भी शामिल है।
विजुअल स्टूडियो के साथ पूर्वापेक्षाएँ
.NET कोर एसडीके का उपयोग करके .NET कोर अनुप्रयोगों को विकसित करने के लिए, आप अपनी पसंद के किसी भी संपादक का उपयोग कर सकते हैं।
हालाँकि, यदि आप Visual Studio का उपयोग करके Windows पर .NET Core एप्लिकेशन विकसित करना चाहते हैं, तो आप निम्न दो संस्करणों का उपयोग कर सकते हैं -
विजुअल स्टूडियो 2015
विजुअल स्टूडियो 2017 आर.सी.
विजुअल स्टूडियो 2015 के साथ बनाई गई परियोजनाएँ प्रोजेक्ट-जसन-डिफ़ॉल्ट रूप से आधारित होंगी, जबकि विज़ुअल स्टूडियो 2017 आरसी के साथ बनाई गई परियोजनाएँ हमेशा MSBuild- आधारित होंगी।
इस अध्याय में, हम .NET कोर के पर्यावरण सेटअप पर चर्चा करेंगे। यह .NET फ्रेमवर्क का एक महत्वपूर्ण नया स्वरूप है। अपने अनुप्रयोग में .NET कोर का उपयोग करने के लिए, दो संस्करण हैं जिनका आप उपयोग कर सकते हैं -
- विजुअल स्टूडियो 2015
- विजुअल स्टूडियो 2017 आर.सी.
विजुअल स्टूडियो 2015
Visual Studio 2015 का उपयोग करने के लिए, आपको निम्नलिखित स्थापित करना होगा -
- Microsoft Visual Studio 2015 अद्यतन 3
- Microsoft .NET कोर 1.0.1 - वीएस 2015 टूलिंग पूर्वावलोकन 2
Microsoft दृश्य स्टूडियो का एक निःशुल्क संस्करण प्रदान करता है जिसमें SQL सर्वर भी होता है और इससे डाउनलोड किया जा सकता है https://www.visualstudio.com/en-us/downloads/download-visual-studio-vs.aspx और Microsoft .NET कोर 1.0.1 - वीएस 2015 टूलिंग प्रीव्यू 2 से डाउनलोड किया जा सकता है https://www.visualstudio.com/downloads/
आप निम्न यूआरएल पर स्थापना दिशानिर्देशों का भी पालन कर सकते हैं https://www.microsoft.com/net/core/#windowsvs2017
विजुअल स्टूडियो 2015 की स्थापना
Visual Studio 2015 स्थापित करने के लिए इन चरणों का पालन करें -
Step 1- एक बार जब डाउनलोडिंग पूरी हो जाए, तो इंस्टॉलर को चलाएं। निम्नलिखित संवाद बॉक्स प्रदर्शित किया जाएगा।
Step 2 - क्लिक करें Install स्थापना प्रक्रिया शुरू करने के लिए।
Step 3 - इंस्टॉलेशन पूरा होने के बाद, आपको निम्नलिखित डायलॉग बॉक्स दिखाई देगा।
Step 4 - इस संवाद को बंद करें और यदि आवश्यक हो तो अपने कंप्यूटर को पुनरारंभ करें।
Step 5- स्टार्ट मेनू से विजुअल स्टूडियो खोलें; आपको निम्नलिखित संवाद बॉक्स प्राप्त होगा। लोड करने में कुछ मिनट लग सकते हैं और अंत में पहली बार उपयोग किया जा सकता है।
Step 6 - लोड होते ही आपको निम्न स्क्रीन दिखाई देगी।
Step 7 - एक बार जब विजुअल स्टूडियो इंस्टॉलेशन समाप्त हो जाता है, तो विजुअल स्टूडियो को बंद करें और Microsoft .NET कोर - वीएस 2015 टूलिंग प्रीव्यू 2 लॉन्च करें।
Step 8 - चेकबॉक्स चेक करें और इंस्टॉल पर क्लिक करें।
Step 9 - इंस्टॉलेशन पूरा होने के बाद, आपको निम्नलिखित डायलॉग बॉक्स दिखाई देगा।
अब आप .NET Core का उपयोग करके अपना आवेदन शुरू करने के लिए तैयार हैं।
विजुअल स्टूडियो 2017
इस ट्यूटोरियल में, हम Visual Studio 2015 का उपयोग करेंगे, लेकिन यदि आप Visual Studio 2017 का उपयोग करना चाहते हैं, तो Visual Studio 2017 RC में Visual Studio के लिए .NET कोर टूल्स की प्रायोगिक रिलीज़ शामिल है और आप यहां इंस्टॉलेशन दिशानिर्देश देख सकते हैं https://www.microsoft.com/net/core/#windowsvs2017
Visual Studio 2015 .NET कोर अनुप्रयोगों को विकसित करने के लिए एक पूर्ण-विशेषताओं वाला विकास परिवेश प्रदान करता है। इस अध्याय में, हम Visual Studio के अंदर एक नई परियोजना का निर्माण करेंगे। एक बार जब आपने Visual Studio 2015 टूलिंग स्थापित कर ली है, तो आप एक नया .NET कोर एप्लीकेशन बनाना शुरू कर सकते हैं।
में New Project संवाद बॉक्स में, टेम्पलेट सूची में, दृश्य C # नोड का विस्तार करें और .NET कोर का चयन करें और आपको निम्नलिखित तीन नए प्रोजेक्ट टेम्पलेट देखने चाहिए
- क्लास लाइब्रेरी (.NET कोर)
- कंसोल एप्लिकेशन (.NET कोर)
- ASP.NET कोर वेब अनुप्रयोग (.NET कोर)
नए प्रोजेक्ट संवाद बॉक्स पर मध्य फलक में, कंसोल एप्लिकेशन (.NET कोर) का चयन करें और इसे "FirstApp" नाम दें, फिर ठीक पर क्लिक करें।
विजुअल स्टूडियो नई बनाई गई परियोजना को खोलेगा, और आप इस प्रोजेक्ट में मौजूद सभी फाइलों के सोल्यूशन एक्सप्लोरर विंडो में देखेंगे।
यह जांचने के लिए कि .NET कोर कंसोल एप्लिकेशन काम कर रहा है, आइए हम निम्नलिखित पंक्ति जोड़ते हैं।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace FirstApp {
public class Program {
public static void Main(string[] args) {
Console.WriteLine("Hello guys, welcome to .NET Core world!");
}
}
}
अब, एप्लिकेशन चलाएँ। आपको निम्न आउटपुट देखना चाहिए।
.NET कोर मानक संख्यात्मक अभिन्न और फ्लोटिंग-पॉइंट प्राइमिटिव का समर्थन करता है। यह निम्नलिखित प्रकारों का भी समर्थन करता है -
System.Numerics.BigInteger जो एक अभिन्न प्रकार है जिसका कोई ऊपरी या निचला भाग नहीं है।
System.Numerics.Complex एक प्रकार है जो जटिल संख्याओं का प्रतिनिधित्व करता है।
System.Numerics नाम स्थान में एकल निर्देश एकाधिक डेटा (SIMD) -सक्रिय वेक्टर प्रकार का एक सेट।
अभिन्न प्रकार
.NET कोर एक बाइट से लेकर आठ बाइट तक लंबाई में विभिन्न श्रेणियों के हस्ताक्षरित और अहस्ताक्षरित दोनों का समर्थन करता है। सभी पूर्णांक मान प्रकार हैं।
निम्न तालिका अभिन्न प्रकार और उनके आकार का प्रतिनिधित्व करती है;
प्रकार | हस्ताक्षरित / बिना हस्ताक्षर किए | आकार (बाइट्स) | न्यूनतम मूल्य | अधिकतम मूल्य |
---|---|---|---|---|
बाइट | अहस्ताक्षरित | 1 | 0 | 255 |
int16 | पर हस्ताक्षर किए | 2 | -32,768 | 32,767 |
int32 | पर हस्ताक्षर किए | 4 | -+२१४७४८३६४८ | 2,147,483,647 |
Int64 | पर हस्ताक्षर किए | 8 | -9.223.372.036.854.775.808 | 9.223.372.036.854.775.807 |
SByte | पर हस्ताक्षर किए | 1 | -128 | 127 |
UInt16 | अहस्ताक्षरित | 2 | 0 | 65,535 |
UInt32 | अहस्ताक्षरित | 4 | 0 | +४२९४९६७२९५ |
UInt64 | अहस्ताक्षरित | 8 | 0 | 18.446.744.073.709.551.615 |
प्रत्येक अभिन्न प्रकार अंकगणित, तुलना, समानता, स्पष्ट रूपांतरण और अंतर्निहित रूपांतरण ऑपरेटरों के एक मानक सेट का समर्थन करता है।
आप System.BitConverter वर्ग का उपयोग करके एक पूर्णांक मान में अलग-अलग बिट्स के साथ भी काम कर सकते हैं।
फ्लोटिंग-पॉइंट प्रकार
.NET कोर में तीन आदिम फ़्लोटिंग पॉइंट प्रकार शामिल हैं, जो निम्न तालिका में दिखाए गए हैं।
प्रकार | आकार (बाइट्स) | न्यूनतम मूल्य | अधिकतम मूल्य |
---|---|---|---|
दोहरा | 8 | -1.79769313486232e308 | 1.79769313486232e308 |
एक | 4 | -3.402823e38 | 3.402823e38 |
दशमलव | 16 | −79,228,162,514,264,337,593,5 43,950,335 | 79,228,162,514,264,337,593,543,9 50,335 |
प्रत्येक फ़्लोटिंग-पॉइंट प्रकार अंकगणित, तुलना, समानता, स्पष्ट रूपांतरण और अंतर्निहित रूपांतरण ऑपरेटरों के एक मानक सेट का समर्थन करता है।
BitConverter वर्ग का उपयोग करके आप व्यक्तिगत बिट्स के साथ डबल और सिंगल मान में भी काम कर सकते हैं।
दशमलव मान के अलग-अलग बिट्स के साथ काम करने के लिए दशमलव संरचना की अपनी विधियाँ हैं, Decimal.GetBits और Decimal.Decimal (Int32 ()), साथ ही साथ कुछ अतिरिक्त गणितीय कार्य करने के लिए तरीकों का अपना सेट है।
BigInteger
System.Numerics.BigInteger एक अपरिवर्तनीय प्रकार है जो एक मनमाने ढंग से बड़े पूर्णांक का प्रतिनिधित्व करता है जिसका सिद्धांत में कोई ऊपरी या निचला सीमा नहीं है।
BigInteger प्रकार की विधियाँ अन्य अभिन्न प्रकारों के समांतर होती हैं।
जटिल
System.Numerics.Complex प्रकार एक जटिल संख्या का प्रतिनिधित्व करता है, अर्थात, एक वास्तविक संख्या भाग के साथ एक संख्या और एक काल्पनिक संख्या भाग
यह अंकगणित, तुलना, समानता, स्पष्ट रूपांतरण और अंतर्निहित रूपांतरण ऑपरेटरों के साथ-साथ गणितीय, बीजीय और त्रिकोणमितीय तरीकों के एक मानक सेट का समर्थन करता है।
SIMD
न्यूमेरिक्स नाम स्थान में .NET कोर के लिए SIMD- सक्षम वेक्टर प्रकार का एक सेट शामिल है।
SIMD कुछ ऑपरेशनों को हार्डवेयर स्तर पर समानांतर करने की अनुमति देता है, जिसके परिणामस्वरूप गणितीय, वैज्ञानिक और ग्राफिक्स ऐप्स में भारी प्रदर्शन में सुधार होता है, जो वैक्टर पर गणना करते हैं।
.NET कोर में SIMD- सक्षम वेक्टर प्रकारों में निम्नलिखित शामिल हैं -
System.Numerics.Vector2, System.Numerics.Vector3, और System.Numerics.Vector4 प्रकार, जो 2, 3 और 4-प्रकार के एकल के वैक्टर हैं।
वेक्टर <T> संरचना जो आपको किसी भी आदिम संख्यात्मक प्रकार के वेक्टर बनाने की अनुमति देती है। आदिम संख्यात्मक प्रकारों में दशमलव के अलावा सिस्टम नामस्थान के सभी संख्यात्मक प्रकार शामिल होते हैं।
दो मैट्रिक्स प्रकार, System.Numerics.Matrix3 × 2, जो 3 × 2 मैट्रिक्स का प्रतिनिधित्व करता है; और System.Numerics.Matrix4 × 4, जो 4 × 4 मैट्रिक्स का प्रतिनिधित्व करता है।
System.Numerics.Plane प्रकार, जो तीन-आयामी विमान का प्रतिनिधित्व करता है, और System.Numerics.Quaternion प्रकार, जो एक वेक्टर का प्रतिनिधित्व करता है जिसका उपयोग तीन-आयामी भौतिक घुमावों को एनकोड करने के लिए किया जाता है।
इस अध्याय में, हम कचरा संग्रह की अवधारणा को कवर करेंगे जो .NET प्रबंधित कोड प्लेटफ़ॉर्म की सबसे महत्वपूर्ण विशेषताओं में से एक है। कचरा संग्रहकर्ता (जीसी) स्मृति के आवंटन और रिलीज का प्रबंधन करता है। कचरा संग्राहक एक स्वचालित मेमोरी मैनेजर के रूप में कार्य करता है।
आपको यह जानने की आवश्यकता नहीं है कि मेमोरी कैसे आवंटित करें और जारी करें या उस मेमोरी का उपयोग करने वाले ऑब्जेक्ट के जीवनकाल का प्रबंधन करें
जब भी आप किसी ऑब्जेक्ट को "नए" कीवर्ड के साथ घोषित करते हैं तो एक आवंटन किया जाता है या एक मूल्य प्रकार बॉक्सिंग किया जाता है। आवंटन आमतौर पर बहुत तेज होते हैं
जब किसी ऑब्जेक्ट को आवंटित करने के लिए पर्याप्त मेमोरी नहीं होती है, तो जीसी को इकट्ठा करना होगा और नए आवंटन के लिए मेमोरी उपलब्ध कराने के लिए कचरा मेमोरी का निपटान करना होगा।
इस प्रक्रिया के रूप में जाना जाता है garbage collection।
कचरा संग्रहण के लाभ
कचरा संग्रह निम्नलिखित लाभ प्रदान करता है -
आपको अपने एप्लिकेशन को विकसित करते समय मेमोरी को मैन्युअल रूप से खाली करने की आवश्यकता नहीं है।
यह प्रबंधित हीप पर वस्तुओं को कुशलता से आवंटित भी करता है।
जब वस्तुओं का उपयोग नहीं किया जाता है तो यह उन वस्तुओं को उनकी स्मृति को पुनः प्राप्त कर देगा, और स्मृति को भविष्य के आवंटन के लिए उपलब्ध रखेगा।
प्रबंधित ऑब्जेक्ट स्वचालित रूप से शुरू करने के लिए स्वच्छ सामग्री प्राप्त करते हैं, इसलिए उनके कंस्ट्रक्टरों को हर डेटा फ़ील्ड को प्रारंभ करने की आवश्यकता नहीं है।
यह यह सुनिश्चित करके स्मृति सुरक्षा भी प्रदान करता है कि एक वस्तु किसी अन्य वस्तु की सामग्री का उपयोग नहीं कर सकती है।
कचरा संग्रहण की शर्तें
कचरा संग्रह तब होता है जब निम्न में से कोई एक स्थिति सत्य होती है।
सिस्टम में कम भौतिक मेमोरी है।
प्रबंधित हीप पर आवंटित ऑब्जेक्ट द्वारा उपयोग की जाने वाली मेमोरी एक स्वीकार्य सीमा से अधिक है। प्रक्रिया के चलते ही यह सीमा लगातार समायोजित हो जाती है।
GC.Collectविधि कहा जाता है और लगभग सभी मामलों में, आपको इस पद्धति को कॉल करने की आवश्यकता नहीं है, क्योंकि कचरा कलेक्टर लगातार चलता है। इस पद्धति का उपयोग मुख्य रूप से अद्वितीय स्थितियों और परीक्षण के लिए किया जाता है।
पीढ़ियों
.NET गारबेज कलेक्टर के पास 3 पीढ़ियाँ होती हैं और प्रत्येक पीढ़ी का अपना ढेर होता है जिसका उपयोग आवंटित वस्तुओं के भंडारण के लिए किया जाता है। एक बुनियादी सिद्धांत है कि ज्यादातर वस्तुएं या तो अल्पकालिक हैं या लंबे समय से जीवित हैं।
जनरेशन फ़र्स्ट (0)
जनरेशन 0 में, ऑब्जेक्ट पहले आवंटित किए जाते हैं।
इस पीढ़ी में, ऑब्जेक्ट अक्सर पहली पीढ़ी से अधिक नहीं रहते हैं, क्योंकि वे अगले कचरा संग्रह के समय तक उपयोग (दायरे से बाहर) नहीं होते हैं।
जनरेशन 0 इकट्ठा करने के लिए जल्दी है क्योंकि इसका संबद्ध ढेर छोटा है।
जनरेशन सेकंड (1)
जनरेशन 1 में, ऑब्जेक्ट्स के पास दूसरा मौका है।
वे वस्तुएं जो अल्पकालिक हैं, लेकिन पीढ़ी 0 संग्रह से बच जाती हैं (अक्सर संयोग के समय पर आधारित होती हैं) पीढ़ी 1 पर जाती हैं।
जनरेशन 1 संग्रह भी त्वरित हैं क्योंकि इसका संबद्ध ढेर भी छोटा है।
पहले दो ढेर छोटे बने हुए हैं क्योंकि वस्तुओं को या तो एकत्र किया जाता है या अगली पीढ़ी के ढेर में बढ़ावा दिया जाता है।
जनरेशन थर्ड (2)
जनरेशन 2 में, सभी लंबी वस्तुएँ रहती हैं और इसका ढेर बहुत बड़ा हो सकता है।
इस पीढ़ी में वस्तुएं लंबे समय तक जीवित रह सकती हैं और वस्तुओं को आगे बढ़ाने के लिए अगली पीढ़ी का ढेर नहीं है।
गारबेज कलेक्टर के पास लार्ज ऑब्जेक्ट हीप (LOH) नामक बड़ी वस्तुओं के लिए एक अतिरिक्त ढेर है।
यह उन वस्तुओं के लिए आरक्षित है जो 85,000 बाइट्स या अधिक हैं।
बड़ी वस्तुओं को जेनेरिक हील्स के लिए आवंटित नहीं किया जाता है, लेकिन एलओएच को सीधे आवंटित किया जाता है
पीढ़ी 2 और LOH संग्रह उन कार्यक्रमों के लिए ध्यान देने योग्य समय ले सकते हैं जो लंबे समय तक चले हैं या बड़ी मात्रा में डेटा संचालित करते हैं।
ज्ञात है कि बड़े सर्वर प्रोग्राम 10s के GB में ढेर होते हैं।
जीसी समय की मात्रा को कम करने के लिए कई प्रकार की तकनीकों को नियुक्त करता है जो कि कार्यक्रम के निष्पादन को अवरुद्ध करता है।
प्राथमिक दृष्टिकोण यह है कि एक पृष्ठभूमि धागे पर जितना संभव हो उतना कचरा संग्रह कार्य करना है जो कार्यक्रम के निष्पादन में हस्तक्षेप नहीं करता है।
जीसी डेवलपर्स को अपने व्यवहार को प्रभावित करने के लिए कुछ तरीके भी उजागर करता है, जो प्रदर्शन को बेहतर बनाने के लिए काफी उपयोगी हो सकता है।
इस अध्याय में, हम .NET कोर की निष्पादन प्रक्रिया को समझेंगे और इसकी तुलना .NET फ्रेमवर्क से करेंगे। प्रबंधित निष्पादन प्रक्रिया में निम्नलिखित चरण शामिल हैं।
- एक कंपाइलर चुनना
- अपने कोड को MSIL में संकलित करना
- देशी कोड को MSIL संकलित करना
- रनिंग कोड
एक कंपाइलर चुनना
यह एक बहु-भाषा निष्पादन वातावरण है, रनटाइम विभिन्न प्रकार के डेटा प्रकारों और भाषा सुविधाओं का समर्थन करता है।
सामान्य भाषा रनटाइम द्वारा प्रदान किए गए लाभों को प्राप्त करने के लिए, आपको रनटाइम को लक्षित करने वाले एक या अधिक भाषा कंपाइलरों का उपयोग करना चाहिए।
अपने कोड को MSIL में संकलित करना
संकलन आपके स्रोत कोड को Microsoft मध्यवर्ती भाषा (MSIL) में अनुवादित करता है और आवश्यक मेटाडेटा बनाता है।
मेटाडेटा आपके कोड में प्रकारों का वर्णन करता है, जिसमें प्रत्येक प्रकार की परिभाषा, प्रत्येक प्रकार के सदस्यों के हस्ताक्षर, आपके कोड का संदर्भ देने वाले सदस्य और अन्य डेटा जो रनटाइम निष्पादन के समय उपयोग करते हैं।
रनटाइम फ़ाइल के मेटाडेटा के साथ-साथ फ्रेमवर्क क्लास लाइब्रेरीज़ (FCL) से निष्पादित होने के दौरान आवश्यक हो जाता है।
मूल कोड के लिए MSIL संकलन
निष्पादन समय पर, एक जस्ट-इन-टाइम (JIT) कंपाइलर MSIL को देशी कोड में बदल देता है।
इस संकलन के दौरान, कोड को एक सत्यापन प्रक्रिया पास करनी होगी जो एमएसआईएल और मेटाडेटा की जांच करती है ताकि यह पता लगाया जा सके कि क्या कोड सुरक्षित होने के लिए निर्धारित किया जा सकता है।
रनिंग कोड
सामान्य भाषा रनटाइम इंफ्रास्ट्रक्चर प्रदान करता है जो निष्पादन को सक्षम बनाता है और निष्पादन के दौरान उपयोग की जा सकने वाली सेवाएं प्रदान करता है।
निष्पादन के दौरान, प्रबंधित कोड कचरा संग्रह, सुरक्षा, अप्रबंधित कोड के साथ इंटरऑपरेबिलिटी, क्रॉस-लैंग्वेज डीबगिंग समर्थन, और वर्धित परिनियोजन और संस्करण समर्थन जैसी सेवाएँ प्राप्त करता है।
.NET कोर कोड निष्पादन प्रक्रिया
अब आइए .NET फ्रेमवर्क की तुलना में .NET कोर के साथ कोड कैसे निष्पादित होता है। .NET कोर में इन घटकों के कई प्रतिस्थापन हैं जो .NET फ्रेमवर्क का हिस्सा हैं।
.NET कोर में अब हमारे पास संकलक की एक नई श्रृंखला है, जैसे हमारे पास C # और VB के लिए रोजलिन है।
यदि आप .NET कोर के साथ F # का उपयोग करना चाहते हैं तो आप नए F # 4.1 कंपाइलर का उपयोग भी कर सकते हैं।
वास्तव में ये उपकरण अलग-अलग हैं और हम रोज़ फ्रेमवर्क के साथ .NET फ्रेमवर्क का उपयोग कर सकते हैं यदि हम C # 6 या उसके बाद का उपयोग कर रहे हैं, क्योंकि C # कंपाइलर केवल C # 5 तक ही समर्थन कर सकता है।
.NET Core में, हमारे पास फ्रेमवर्क क्लास लाइब्रेरीज़ (FCL) नहीं है, इसलिए लाइब्रेरीज़ का एक अलग सेट उपयोग किया जाता है और हमारे पास अब Corexx है।
CoreFx .NET कोर के लिए कक्षा पुस्तकालयों का पुन: कार्यान्वयन है।
हमारे पास .NET Core के साथ एक नया रन टाइम है जिसे CoreCLR के रूप में जाना जाता है और एक JIT कंपाइलर का लाभ उठाता है।
अब सवाल यह है कि हमारे पास .NET फ्रेमवर्क में पहले से मौजूद इन सभी घटकों का पुन: कार्यान्वयन क्यों है।
तो इसका उत्तर भी यही है कि Microsoft ने .NET Core क्यों लागू किया।
यह मॉड्यूलर कि आवेदन बनाने और लागू करने के लिए .NET कोर का एक और विचार है। पूरे .NET फ्रेमवर्क को स्थापित करने के बजाय, आपका एप्लिकेशन अब केवल वही इंस्टॉल कर सकता है जो आवश्यक है। आइए हम दृश्य स्टूडियो में जाएं और मॉड्यूलरिटी देखें।
यहाँ समाधान एक्सप्लोरर में हमारी सरल .NET कोर एप्लीकेशन है। आइए हम संदर्भों का विस्तार करें और आप .NETCoreApp के संदर्भ देखेंगे
.NETCoreApp के अंदर, आप NuGet को पैकेज संदर्भ देखेंगे; हमें इसका विस्तार करने दें।
आप NuGet पैकेज संदर्भ की पूरी श्रृंखला देखेंगे। यदि आपने .NET फ्रेमवर्क में काम किया है, तो इनमें से कई नामस्थान परिचित होंगे, क्योंकि आप इसका उपयोग .NET फ्रेमवर्क में उपयोग करके करते हैं।
.NET फ्रेमवर्क कई अलग-अलग टुकड़ों में विभाजित है और CoreFx के साथ फिर से लागू किया गया है; इन टुकड़ों को अलग-अलग पैकेज के रूप में वितरित किया जाता है।
अब यदि आप NETStandard.Library का विस्तार करते हैं, तो आपको अतिरिक्त संदर्भ दिखाई देंगे। यहां तक कि आप System.Console को भी नोटिस करेंगे जो हम इस एप्लिकेशन में उपयोग कर रहे हैं।
अब आपको .NET फ्रेमवर्क के अंदर सब कुछ लाने की ज़रूरत नहीं है, लेकिन आपको अपने आवेदन के लिए जो चाहिए वह लाना होगा।
कुछ अन्य लाभ भी हैं; उदाहरण के लिए, इन मॉड्यूल को व्यक्तिगत रूप से अपडेट किया जा सकता है यदि वांछित हो।
प्रतिरूपकता प्रदर्शन लाभ की ओर ले जाती है और आपका अनुप्रयोग तेजी से चल सकता है, विशेष रूप से ASP.NET कोर अनुप्रयोग।
इस अध्याय में, हम .NET कोर प्रोजेक्ट फ़ाइलों पर चर्चा करेंगे और आप अपने प्रोजेक्ट में मौजूदा फ़ाइलों को कैसे जोड़ सकते हैं।
आइए एक सरल उदाहरण को समझते हैं जिसमें हमारे पास कुछ फाइलें हैं जो पहले से ही निर्मित हैं; हमें अपने FirstApp प्रोजेक्ट में इन फ़ाइलों को जोड़ना होगा।
यहाँ का कार्यान्वयन है Student.cs फ़ाइल
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace FirstApp {
public class Student {
public int ID { get; set; }
public string LastName { get; set; }
public string FirstMidName { get; set; }
public DateTime EnrollmentDate { get; set; }
}
}
यहाँ का कार्यान्वयन है Course.cs फ़ाइल।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace FirstApp {
public class Course {
public int CourseID { get; set; }
public string Title { get; set; }
public int Credits { get; set; }
}
}
आइए अब हम इन तीन फाइलों को आपकी डिस्क और आपके प्रोजेक्ट के स्रोत फ़ोल्डर में सहेजते हैं।
अब यदि आप .NET से परिचित हैं और यह एक पारंपरिक .NET फ्रेमवर्क कंसोल एप्लिकेशन था, तो यह समझना महत्वपूर्ण है कि विज़ुअल स्टूडियो में अपने प्रोजेक्ट में इन फ़ाइलों को कैसे जोड़ा जाए।
आपको पहले अपने प्रोजेक्ट फ़ोल्डर में उन्हें कॉपी करने के लिए फ़ाइलों को सॉल्यूशन एक्सप्लोरर में ले जाना होगा, क्योंकि आपके प्रोजेक्ट को इन फाइलों के संदर्भ की आवश्यकता है।
.NET कोर के लाभों में से एक परियोजना फ़ाइल (project.json) के साथ लिया गया दृष्टिकोण है; हम बस अपने प्रोजेक्ट के मूल में फाइल छोड़ सकते हैं और फिर ये स्वचालित रूप से हमारी परियोजना में शामिल हो जाएंगे।
विज़ुअल स्टूडियो में पारंपरिक .NET फ्रेमवर्क एप्लिकेशन के लिए हमने अतीत में मैन्युअल रूप से संदर्भ फ़ाइलों को नहीं किया है।
आइए अब हम आपके प्रोजेक्ट का रूट खोलते हैं।
आइए अब हम तीनों फाइलों को अपने प्रोजेक्ट के रूट में कॉपी करें।
अब आप रूट फ़ोल्डर में कॉपी की गई सभी फाइलों को देख सकते हैं।
अब हम विजुअल स्टूडियो में जाते हैं; आपको निम्नलिखित संवाद बॉक्स प्राप्त होगा।
क्लिक Yes to All अपने प्रोजेक्ट को पुनः लोड करने के लिए।
अब आप देखेंगे कि फ़ाइलें आपके प्रोजेक्ट में स्वचालित रूप से शामिल हैं।
इस अध्याय में, हम चर्चा करेंगे कि अपने .NET कोर एप्लीकेशन में पैकेज कैसे जोड़ें और एक विशिष्ट पैकेज कैसे खोजें। हम सीधे NuGet पर जा सकते हैं और पैकेज जोड़ सकते हैं, लेकिन यहां हम कुछ अन्य स्थानों को देखेंगे।
आइये अब .NET कोर के सोर्स कोड पर जाएँ जो यहाँ स्थित है - https://github.com/dotnet/corefx
CoreFx रेपो में, खोलें src फ़ोल्डर -
और आपको फ़ोल्डर्स की पूरी सूची दिखाई देगी जो विभिन्न पैकेजों के अनुरूप हैं। आइए अब हम Json खोजते हैं -
अपने पैकेज को खोजने का एक और तरीका है, आप शायद विभिन्न प्रकारों को जानते हैं। यदि आप .NET फ्रेमवर्क से परिचित हैं, लेकिन .NET कोर में पैकेजों की असेंबलिंग पूरी तरह से अलग है और आपको पता नहीं चलेगा कि पैकेज कहाँ हैं।
यदि आप प्रकार जानते हैं, तो आप उपयोग करके पैकेज खोज को उल्टा कर सकते हैं https://packagesearch.azurewebsites.net/
यहां आप किसी भी प्रकार का पैकेज दर्ज कर सकते हैं जिसे आप ढूंढना चाहते हैं। फिर, यह साइट NuGet को स्कैन करेगी और आपके लिए प्रासंगिक पैकेजों को खोजेगी।
अब हम खोजते हैं DataContractJson।
अब आप देखेंगे कि हमें वही पैकेज मिलेगा; पैकेज पर क्लिक करें।
अब आप NuGet पेज देखेंगे; आपको यह पुष्टि करने की आवश्यकता है कि आपको इस पैकेज की आवश्यकता है। आप कुछ विधियों का उपयोग करके इसे अपने एप्लिकेशन में जोड़ सकते हैं।
हमें project.json फ़ाइल खोलें।
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
}
},
"frameworks": {
"netcoreapp1.0": {
"imports": "dnxcore50"
}
}
}
यह नया प्रोजेक्ट प्रारूप है और इस फ़ाइल के अंदर आपको निर्भरता अनुभाग दिखाई देगा। हमें एक नई निर्भरता जोड़ते हैं जैसा कि नीचे दिखाया गया है।
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
},
"System.Runtime.Serialization.Json": "4.0.2"
},
"frameworks": {
"netcoreapp1.0": {
"imports": "dnxcore50"
}
}
}
अब यदि आप अपने संदर्भों को देखते हैं, तो आप इसे देखेंगे System.Runtime.Serialization.Json पैकेज आपके प्रोजेक्ट में जोड़ा जाता है।
दूसरा तरीका यह है कि आप NuGet Manager में जाएं और उस पैकेज को ब्राउज़ करें जिसे आप जोड़ना चाहते हैं।
इस अध्याय में, हम चर्चा करेंगे कि .NET कोर का उपयोग करके UWP एप्लिकेशन कैसे बनाया जाए। UWP को विंडोज 10 UWP एप्लिकेशन के रूप में भी जाना जाता है। यह एप्लिकेशन विंडोज के पिछले संस्करणों पर नहीं चलता है, बल्कि केवल विंडोज के भविष्य के संस्करण पर चलेगा।
निम्नलिखित कुछ अपवाद हैं जहां यूडब्ल्यूपी आसानी से चलेगा।
यदि आप इसे स्थानीय रूप से चलाना चाहते हैं तो आपके पास विंडोज 10 होना चाहिए, आप विंडोज 8 पर भी विकसित कर सकते हैं और फिर आपको इसे एमुलेटर पर चलाने की आवश्यकता होगी, लेकिन इसे विंडोज 10 का उपयोग करने के लिए प्रोत्साहित किया जाता है।
UWP एप्लिकेशन के लिए आपको विंडोज 10 एसडीके की भी आवश्यकता होगी। हमें Visual Studio 2015 सेटअप खोलें और फिर Visual Studio संशोधित करें।
चुनिंदा फ़ीचर्स पेज पर, नीचे स्क्रॉल करें और आपको यूनिवर्सल विंडोज ऐप डेवलपमेंट टूल्स दिखाई देगा, नीचे दिए गए विकल्प की जाँच करें।
यहां आप एसडीके के विभिन्न संस्करणों और टूल पर नवीनतम अपडेट भी देख सकते हैं, अगला क्लिक करें।
अब, क्लिक करें Install बटन।
एक बार स्थापना समाप्त हो जाने के बाद, आपको अपने सिस्टम को पुनरारंभ करना होगा।
आइए अब हम इन चरणों का पालन करके UWP को लागू करते हैं।
सबसे पहले, Visual Studio 2015 लॉन्च करें।
फ़ाइल मेनू पर क्लिक करें और नया → प्रोजेक्ट चुनें; एक नया प्रोजेक्ट संवाद दिखाई देगा। आप संवाद बॉक्स के बाएँ फलक पर विभिन्न प्रकार के टेम्पलेट देख सकते हैं।
बाएं फलक में, आप ट्री व्यू देख सकते हैं, अब टेम्प्लेट्स → विज़ुअल C # → विंडोज से यूनिवर्सल टेम्पलेट चुनें।
केंद्र फलक से, ब्लैंक ऐप (यूनिवर्सल विंडोज) टेम्पलेट का चयन करें।
टाइप करके प्रोजेक्ट को एक नाम दें UWPFirstApp नाम फ़ील्ड में और ठीक पर क्लिक करें।
लक्ष्य संस्करण / न्यूनतम संस्करण संवाद प्रकट होता है। इस ट्यूटोरियल के लिए डिफ़ॉल्ट सेटिंग्स ठीक हैं, इसलिए प्रोजेक्ट बनाने के लिए ओके का चयन करें।
यहां, हमारे पास एक एकल परियोजना है जो सभी विंडोज 10 डिवाइसेस को लक्षित कर सकती है, और आप देखेंगे कि .NET कोर और UWP दोनों बहु-लक्ष्यीकरण का सरलीकरण हैं।
जब कोई नया प्रोजेक्ट खुलता है, तो उसकी फाइलें सॉल्यूशन एक्सप्लोरर फलक के दाईं ओर प्रदर्शित होती हैं। आपको अपनी फ़ाइलों को देखने के लिए गुण टैब के बजाय समाधान एक्सप्लोरर टैब चुनने की आवश्यकता हो सकती है।
हालाँकि Blank App (Universal Window) एक न्यूनतम टेम्पलेट है, फिर भी इसमें बहुत सारी फाइलें हैं। ये फ़ाइलें C # का उपयोग करके सभी UWP ऐप्स के लिए आवश्यक हैं। Visual Studio में आपके द्वारा बनाए गए प्रत्येक प्रोजेक्ट में फ़ाइलें होती हैं।
चल रहे उदाहरण को देखने के लिए, हमें MainPage.XAML खोलें और निम्न कोड जोड़ें।
<Page
x:Class = "UWPFirstApp.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPFirstApp"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel HorizontalAlignment = "Center">
<TextBlock Text = "Hello, world!"
Margin = "20"
Width = "200"
HorizontalAlignment = "Left"/>
<TextBlock Text = "Write your name."
Margin = "20"
Width = "200"
HorizontalAlignment = "Left"/>
<TextBox x:Name = "txtbox"
Width = "280"
Margin = "20"
HorizontalAlignment = "Left"/>
<Button x:Name = "button" Content = "Click Me"
Margin = "20"
Click = "button_Click"/>
<TextBlock x:Name = "txtblock"
HorizontalAlignment = "Left"
Margin = "20"/>
</StackPanel>
</Grid>
</Page>
नीचे C # में बटन का क्लिक इवेंट है।
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Navigation;
// The Blank Page item template is documented at
// http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPHellowWorld {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private void button_Click(object sender, RoutedEventArgs e) {
if (txtbox.Text != "")
txtblock.Text = "Hello: " + txtbox.Text;
else
txtblock.Text = "You have not write your name";
}
}
}
अब हम स्थानीय मशीन पर उपरोक्त कोड चलाते हैं और आपको निम्न विंडो दिखाई देगी। अब टेक्स्ट बॉक्स में कोई भी नाम लिखें और दबाएंClick Me बटन।
इस अध्याय में, हम चर्चा करेंगे कि MSBuild क्या है और यह .NET कोर के साथ कैसे काम करता है। MSBuild Microsoft और Visual Studio का बिल्ड प्लेटफ़ॉर्म है। UWP एप्लिकेशन में यदि आप प्रोजेक्ट फ़ोल्डर खोलते हैं, तो आप दोनों प्रोजेक्ट देखेंगे। json और * .csproj फाइलें।
लेकिन यदि आप हमारे पिछले .NET कोर कंसोल ऐप को खोलते हैं, तो आपको प्रोजेक्ट.जेसन और * .xproj फाइलें दिखाई देंगी।
.NET कोर बिल्ड सिस्टम या प्रोजेक्ट.जॉन बिल्ड सिस्टम UWP की जरूरतों के लिए पर्याप्त नहीं है; यही कारण है कि UWP अभी भी * .csproj (MSBuild) बिल्ड सिस्टम का उपयोग कर रहा है।
लेकिन जहां तक बिल्ड सिस्टम की बात है प्रोजेक्ट.जॉन बाहर निकल जाएगा।
अब यदि आप अपने UWP एप्लिकेशन में कुछ मौजूदा फ़ाइलों को जोड़ना चाहते हैं जैसा कि हमने कंसोल ऐप में जोड़ा है, तो आपको प्रोजेक्ट फ़ोल्डर में उन फ़ाइलों को जोड़ना होगा। इसके अलावा, आपको अपने प्रोजेक्ट को सोल्यूशन एक्सप्लोरर में भी शामिल करना होगा।
अब हम निम्नलिखित फाइलों पर विचार करते हैं; इन फ़ाइलों को अपने प्रोजेक्ट फ़ोल्डर में कॉपी करें।
आइए हम विजुअल स्टूडियो में वापस जाएं और समाधान एक्सप्लोरर खोलें।
अब आप देख सकते हैं कि UWP अनुप्रयोगों के मामले में केवल नकल फ़ाइलें पर्याप्त नहीं हैं, क्योंकि समाधान एक्सप्लोरर में, हम उन फ़ाइलों को नहीं देख सकते हैं।
अब हमें उन फाइलों को भी शामिल करना होगा, जिन पर क्लिक करके Show All Files ऊपर दिए गए स्क्रीनशॉट में हाइलाइट किया गया आइकन और आप प्रोजेक्ट फ़ोल्डर में अब सभी फाइलें देखेंगे।
ये दो फाइलें अभी भी हमारी परियोजना में शामिल नहीं हैं। इन फ़ाइलों को शामिल करने के लिए, इन फ़ाइलों का चयन करें और किसी भी फ़ाइल पर राइट-क्लिक करें और फिर चुनेंInclude in Project।
अब ये फाइलें भी शामिल हैं। एक अच्छी बात यह है कि पूर्वाभास किया जा सकता है। परियोजना के लिए। एससीडी टूल्स के भविष्य के संस्करण में * .csproj के लिए और।
इस अध्याय में, हम अपने कंसोल ऐप और हमारे UWP ऐप के बीच के संदर्भों पर चर्चा करेंगे। यदि आप अपने कंसोल एप्लिकेशन के समाधान एक्सप्लोरर में संदर्भों को देखते हैं, तो आप नीचे दिखाए गए अनुसार .NETCoreApp देखेंगे।
.NET कोर एप एक नया ढांचा है जिसने .NET कोर एप्लिकेशन को लक्षित किया है। अब यदि आप UWP एप्लिकेशन के संदर्भ के तहत देखते हैं, तो यह नीचे दिखाए गए अनुसार थोड़ा अलग दिखाई देगा।
इसका मुख्य कारण यह है कि यहां UWP में हमारे पास * .csproj है, इसलिए हम संदर्भों की पुरानी शैली पर वापस आ गए हैं और हम इस परियोजना के प्रकार के साथ केवल एक रूपरेखा को लक्षित कर सकते हैं।
संदर्भ हालांकि समान हैं। अब आप देख सकते हैं कि UWP एप्लिकेशन में Miscrosoft.NETCore.UniversalWindowsPlatform NuGet पैकेज संदर्भ Microsoft.NETCore.App NuGet संदर्भ कंसोल एप्लिकेशन के समान है।
Miscrosoft.NETCore.UniversalWindowsPlatform और Microsoft.NETCore.App दोनों मेटा-पैकेज हैं, जिसका अर्थ है कि वे अन्य पैकेजों से बने हैं।
कंसोल एप्लिकेशन में, हम Microsoft.NETCore.App के अंदर अन्य पैकेजों को ड्रिल कर सकते हैं और देख सकते हैं, लेकिन हम समाधान एक्सप्लोरर में एक ही Miscrosoft.NETCore.UniversalWindowsPlatform नहीं कर सकते।
हालाँकि, हम इसे देखने के लिए एक अन्य टूल, NuGet Package एक्सप्लोरर का उपयोग कर सकते हैं। आइए अब हम इस url को ब्राउज़र में खोलें -https://npe.codeplex.com/downloads/get/clickOnce/NuGetPackageExplorer.application और आपको एक छोटी उपयोगिता डाउनलोड होती दिखाई देगी।
एक बार डाउनलोड पूरा होने पर, फिर उस फ़ाइल पर डबल-क्लिक करें।
क्लिक Install NuGet पैकेज एक्सप्लोरर पर स्थापना शुरू करने के लिए।
जब स्थापना समाप्त हो जाती है, तो आपको निम्नलिखित संवाद बॉक्स दिखाई देगा।
अब हम पर क्लिक करते हैं Open a package from online feed विकल्प।
डिफ़ॉल्ट रूप से यह nuget.org फ़ीड की खोज करेगा। अब हम खोज बॉक्स में Microsoft.NETCore.UniversalWindowsPlatform की खोज करते हैं और आपको नीचे दिखाए गए अनुसार 1 परिणाम दिखाई देगा।
दबाएं open लिंक और यह इस रूपक की शीर्ष-स्तरीय निर्भरता को खोलेगा।
आइए अब हम NETCore एप्लीकेशन के लिए .NETCore मेटा पैकेज खोलते हैं और UWP एप्लीकेशन साइड के लिए मेटा-पैकेज साइड से करते हैं।
अब आप देख सकते हैं कि प्रत्येक मेटा-पैकेज पैकेज के विभिन्न सेट से बना है।
.NET कोर कम से कम इस समय .NET फ्रेमवर्क में उपलब्ध कक्षाओं का एक सबसेट है, लेकिन बढ़ रहा है और .NET फ्रेमवर्क के आधार वर्गों के अनुसार होगा।
UWP .NET Core पर आधारित है, यह विंडोज स्टोर के विकास के लिए उपलब्ध एपीआई का एक सुपरसेट है।
अब हमारे पास .NET कोर के कारण विकास के लिए अधिक API उपलब्ध हैं।
विंडोज रनटाइम घटक स्व-निहित वस्तुएं हैं जिन्हें आप C #, विजुअल बेसिक, जावास्क्रिप्ट और C ++ सहित किसी भी भाषा से त्वरित और उपयोग कर सकते हैं। .NET कोर मेटा-पैकेज के अलावा हमने पिछले अध्याय में देखा, UWP ऐप में एक यूनिवर्सल विंडोज केआरके के लिए डिफ़ॉल्ट रूप से एक संदर्भ भी है।
यूनिवर्सल विंडोज विंडोज रनटाइम का संदर्भ है और इसे एपीआई अनुबंधों की एक श्रृंखला में शामिल किया गया है।
एक उपकरण परिवार के भीतर एपीआई का सेट उप अनुबंधों में टूट जाता है जिसे एपीआई अनुबंध के रूप में जाना जाता है। आप यहां विभिन्न एपीआई अनुबंधों की एक सूची पा सकते हैंhttps://msdn.microsoft.com/en-us/library/windows/apps/dn706135.aspx
विंडोज़ रनटाइम के अंदर उन एपीआई में से अधिकांश एक एकल अनुबंध में फैक्टर किए जाते हैं। अब हम API कॉन्ट्रैक्ट पेज पर यूनिवर्सल कीवर्ड की खोज करते हैं।
आप विभिन्न एपीआई के लिंक देख सकते हैं और आप यह भी देख सकते हैं कि यूनिवर्सल परिवार इतना बड़ा है कि इसमें 12 पृष्ठों के दस्तावेज हैं।
आप इस पृष्ठ पर फ़ोन API अनुबंध की खोज भी कर सकते हैं।
अब हम पर क्लिक करते हैं Windows.Phone.PhoneContractऔर नीचे स्क्रॉल करें; अब आप फोन या मोबाइल डिवाइस की बैटरी जानकारी देखेंगे।
यदि आप अपने पास पहले से मौजूद जानकारी को जोड़ना चाहते हैं, तो आपको मैन्युअल रूप से संदर्भ जोड़ना चाहिए। अब हम विजुअल स्टूडियो में जाते हैं और सॉल्यूशन एक्सप्लोरर के संदर्भों पर राइट-क्लिक करते हैं।
चुनते हैं Add References…
अब आप यूनिवर्सल विंडोज के लिए नई संदर्भ श्रेणी देख सकते हैं; इस श्रेणी के तहत कोर है जो कोर यूनिवर्सल विंडोज एपीआई कॉन्ट्रैक्ट को संदर्भित करता है
एक्सटेंशन हमें कार्यक्षमता का विस्तार करने की अनुमति देता है और आप विभिन्न संदर्भ मोबाइल, डेस्कटॉप और अन्य एक्सटेंशन देखेंगे।
अलग-अलग SKD एक्सटेंशन हैं और आप अधिक API प्राप्त करने के लिए शीर्ष पर जोड़ सकते हैं।
आप विभिन्न संस्करणों को भी देख सकते हैं। इसलिए, सुनिश्चित करें कि आपको अपडेटेड API प्राप्त करने के लिए नवीनतम संस्करण प्राप्त हो और फिर OK पर क्लिक करें।
अब आप देख सकते हैं Windows Mobile Extensions for the UWP संदर्भ के रूप में जोड़ा जाता है।
एक क्लास लाइब्रेरी उन प्रकारों और तरीकों को परिभाषित करती है जिन्हें किसी भी एप्लिकेशन से बुलाया जा सकता है।
.NET कोर का उपयोग करके विकसित एक क्लास लाइब्रेरी .NET मानक लाइब्रेरी का समर्थन करती है, जो आपके पुस्तकालय को .NET .NET लाइब्रेरी के उस संस्करण का समर्थन करने वाले किसी भी .NET प्लेटफॉर्म द्वारा कॉल करने की अनुमति देती है।
जब आप अपनी कक्षा की लाइब्रेरी समाप्त कर लेते हैं, तो आप यह तय कर सकते हैं कि क्या आप इसे तृतीय-पक्ष घटक के रूप में वितरित करना चाहते हैं, या क्या आप इसे एक घटक के रूप में शामिल करना चाहते हैं जो एक या अधिक अनुप्रयोगों के साथ बंडल है।
आइए हम अपने कंसोल एप्लिकेशन में एक क्लास लाइब्रेरी प्रोजेक्ट जोड़कर शुरू करें; पर राइट क्लिक करेंsrc समाधान एक्सप्लोरर में फ़ोल्डर और चयन करें Add → New Project…
में Add New Project संवाद बॉक्स, .NET कोर नोड चुनें, फिर क्लास लाइब्रेरी (.NET कोर) प्रोजेक्ट टेम्पलेट चुनें।
नाम पाठ बॉक्स में, प्रोजेक्ट के नाम के रूप में "यूटिलिटीलाइड्स" दर्ज करें, जैसा कि निम्न आंकड़ा दिखाता है।
क्लास लाइब्रेरी प्रोजेक्ट बनाने के लिए ओके पर क्लिक करें। प्रोजेक्ट बनने के बाद, हम एक नया वर्ग जोड़ते हैं। राइट-क्लिक करेंproject समाधान एक्सप्लोरर में और चयन करें Add → Class...
मध्य फलक में वर्ग का चयन करें और नाम और फ़ील्ड में StringLib.cs दर्ज करें और फिर क्लिक करें Add। एक बार क्लास जुड़ने के बाद, StringLib.cs फ़ाइल में निम्न कोड बदलें।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace UtilityLibrary {
public static class StringLib {
public static bool StartsWithUpper(this String str) {
if (String.IsNullOrWhiteSpace(str))
return false;
Char ch = str[0];
return Char.IsUpper(ch);
}
public static bool StartsWithLower(this String str) {
if (String.IsNullOrWhiteSpace(str))
return false;
Char ch = str[0];
return Char.IsLower(ch);
}
public static bool StartsWithNumber(this String str) {
if (String.IsNullOrWhiteSpace(str))
return false;
Char ch = str[0];
return Char.IsNumber(ch);
}
}
}
कक्षा पुस्तकालय, UtilityLibrary.StringLib, कुछ विधियाँ शामिल हैं, जैसे, StartsWithUpper, StartsWithLower, तथा StartsWithNumber जो एक बूलियन मान लौटाता है जो इंगित करता है कि क्या वर्तमान स्ट्रिंग उदाहरण क्रमशः एक अपरकेस, लोअरकेस और संख्या के साथ शुरू होता है।
.NET कोर में Char.IsUpper यदि कोई चरित्र अपरकेस में है, तो विधि सही है, यदि कोई वर्ण कमतर में है, तो Char.IsLower विधि सही साबित होती है, और यदि वर्ण एक सांख्यिक है, तो Char.IsNumber विधि भी सही है।
मेनू बार पर, बिल्ड, बिल्ड सॉल्यूशन चुनें। परियोजना को त्रुटि के बिना संकलित करना चाहिए।
हमारे .NET कोर कंसोल प्रोजेक्ट की हमारी क्लास लाइब्रेरी तक पहुंच नहीं है।
अब इस क्लास लाइब्रेरी का उपभोग करने के लिए हमें अपने कंसोल प्रोजेक्ट में इस क्लास लाइब्रेरी का संदर्भ जोड़ना होगा।
ऐसा करने के लिए, FirstApp का विस्तार करें और संदर्भ पर राइट-क्लिक करें और चुनें Add Reference…
संदर्भ प्रबंधक संवाद बॉक्स में, यूटिलिटी लॉर्ड्स, हमारे क्लास लाइब्रेरी प्रोजेक्ट का चयन करें और फिर क्लिक करें OK।
अब हम कंसोल प्रोजेक्ट के Program.cs फ़ाइल को खोलें और सभी कोड को निम्न कोड से बदलें।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using UtilityLibrary;
namespace FirstApp {
public class Program {
public static void Main(string[] args) {
int rows = Console.WindowHeight;
Console.Clear();
do {
if (Console.CursorTop >= rows || Console.CursorTop == 0) {
Console.Clear();
Console.WriteLine("\nPress <Enter> only to exit; otherwise, enter a string and press <Enter>:\n");
}
string input = Console.ReadLine();
if (String.IsNullOrEmpty(input)) break;
Console.WriteLine("Input: {0} {1,30}: {2}\n", input, "Begins with uppercase? ",
input.StartsWithUpper() ? "Yes" : "No");
} while (true);
}
}
}
चलिए अब हम आपका एप्लिकेशन चलाते हैं और आपको निम्न आउटपुट दिखाई देंगे।
बेहतर समझ के लिए, आइए हम आपकी परियोजना में अपने पुस्तकालय के अन्य विस्तार के तरीकों का उपयोग करें।
इस अध्याय में, हम चर्चा करेंगे कि पीसीएल (पोर्टेबल क्लास लाइब्रेरी) क्या है, और यह भी कि हमें पीसीएल की आवश्यकता क्यों है। इस अवधारणा को समझने के लिए, हम क्लास लाइब्रेरी प्रोजेक्ट फ़ोल्डर खोलें, जिसे हमने पिछले अध्याय में बनाया है।
इस फ़ोल्डर में, आप देख सकते हैं कि Project.json और CS फ़ाइलों के अलावा हमारे पास * .xproj फ़ाइल भी है, और ऐसा इसलिए है क्योंकि Visual Studio setup .NET Core प्रोजेक्ट प्रकार * .xproj के बजाय * .csproj।
जैसा कि Microsoft द्वारा बताया गया है, * .xproj दूर जा रहा है, लेकिन यह अभी भी पूर्वावलोकन 2 टूलिंग में यहाँ है। जैसा कि हमने कवर किया है कि UWP एप्लिकेशन * .csproj का उपयोग करता है।
अब यह वास्तव में संदर्भ के लिए * .csproj प्राप्त करने के लिए संभव नहीं है और * .xproj और यह कार्यक्षमता लागू नहीं होने जा रही है क्योंकि * .xproj बाहर निकल जाएगा।
इसलिए इसके बजाय, हमें एक क्लास लाइब्रेरी की आवश्यकता है जिसे कंसोल ऐप और यूडब्ल्यूपी ऐप के बीच साझा किया जा सकता है और यहां पीसीएल आता है।
PCL क्या है?
आइए अब समझते हैं कि पीसीएल क्या है -
पोर्टेबल क्लास लाइब्रेरी प्रोजेक्ट आपको प्रबंधित असेंबली लिखने और बनाने में सक्षम बनाता है जो एक से अधिक .NET फ्रेमवर्क प्लेटफॉर्म पर काम करते हैं।
आप ऐसी कक्षाएं बना सकते हैं जिनमें आपके द्वारा साझा की जाने वाली व्यावसायिक तर्क जैसे कई परियोजनाओं को साझा करने की इच्छा रखने वाले कोड होते हैं, और फिर उन वर्गों को विभिन्न प्रकार की परियोजनाओं से संदर्भित करते हैं।
यह आपको Microsoft प्लेटफ़ॉर्म के लिए क्रॉस-प्लेटफ़ॉर्म ऐप और लाइब्रेरी बनाने में भी जल्दी और आसानी से मदद कर सकता है।
पोर्टेबल क्लास लाइब्रेरी आपको विकास और परीक्षण कोड के समय और लागत को कम करने में मदद कर सकती हैं।
पोर्टेबल .NET फ्रेमवर्क असेंबलियों को लिखने और बनाने के लिए इस प्रोजेक्ट प्रकार का उपयोग करें, और फिर उन असेंबलीज़ को उन ऐप्स से संदर्भित करें जो कई प्लेटफार्मों जैसे कि विंडोज और विंडोज, आदि को लक्षित करते हैं।
आइए अब हम क्लास लाइब्रेरी को हटाते हैं जिसे हमने सॉल्यूशन एक्सप्लोरर से बनाया है। उसी समय, इसे समाधान फ़ोल्डर से हटा दें और आगे एक नया प्रोजेक्ट आइटम जोड़ें।
को चुनिए Visual C# → Windows बाएँ फलक में टेम्पलेट और मध्य फलक में क्लास लाइब्रेरी (पोर्टेबल) का चयन करें।
नाम फ़ील्ड में StringLibrary दर्ज करें और क्लिक करें OK इस परियोजना को बनाने के लिए।
अब हमें संदर्भ के लिए लक्ष्य रूपरेखा का चयन करने की आवश्यकता है। आइए एक पल के लिए विंडोज यूनिवर्सल और एएसपी.नेट कोर का चयन करें फिर हम इसे पुनः प्राप्त करेंगे। क्लिकOK।
आप देख सकते हैं कि इसने पीसीएफ प्रारूप में एक नई परियोजना बनाई है। अब हम सॉल्यूशन एक्सप्लोरर में StringLibrary प्रोजेक्ट पर राइट-क्लिक करें और गुण चुनें।
लक्ष्य .NET प्लेटफ़ॉर्म मानक पर क्लिक करें।
हाँ पर क्लिक करें; यह अब एक ही वर्ग पुस्तकालय है जिसमें एक मामूली अंतर है। अंतर यह है कि इसका उपयोग UWP द्वारा भी किया जा सकता है, क्योंकि इसमें * .xspj * के बजाय .csproj फ़ाइल है।
अब हम एक नया वर्ग जोड़ते हैं; इसके लिए, आपको समाधान एक्सप्लोरर में प्रोजेक्ट पर राइट-क्लिक करना होगा और चयन करना होगाAdd → Class...
मध्य फलक में वर्ग का चयन करें और दर्ज करें StringLib.cs नाम फ़ील्ड में और फिर क्लिक करें Add। एक बार क्लास जुड़ने के बाद, StringLib.cs फ़ाइल में निम्न कोड बदलें।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace StringLibrary {
public static class StringLib {
public static bool StartsWithUpper(this String str) {
if (String.IsNullOrWhiteSpace(str))
return false;
Char ch = str[0];
return Char.IsUpper(ch);
}
public static bool StartsWithLower(this String str) {
if (String.IsNullOrWhiteSpace(str))
return false;
Char ch = str[0];
return Char.IsLower(ch);
}
public static bool StartsWithNumber(this String str) {
if (String.IsNullOrWhiteSpace(str))
return false;
Char ch = str[0];
return Char.IsNumber(ch);
}
}
}
आइए हम इस पोर्टेबल क्लास लाइब्रेरी प्रोजेक्ट का निर्माण करें और इसे बिना किसी त्रुटि के संकलित करना चाहिए। अब हमें अपने कंसोल प्रोजेक्ट में इस पोर्टेबल क्लास लाइब्रेरी का संदर्भ जोड़ना होगा। इसलिए, FirstApp का विस्तार करें और संदर्भ पर राइट-क्लिक करें और चुनेंAdd Reference…
संदर्भ प्रबंधक संवाद बॉक्स में, StringLibrary का चयन करें जो हमारी पोर्टेबल क्लास लाइब्रेरी प्रोजेक्ट है, और फिर क्लिक करें OK।
आप देख सकते हैं कि StringLibrary संदर्भ कंसोल प्रोजेक्ट में जोड़ा गया है और इसे प्रोजेक्ट.json फ़ाइल में भी देखा जा सकता है।
अब आप एप्लिकेशन को फिर से चला सकते हैं और आपको वही आउटपुट दिखाई देगा।
आइए अब हम अपने प्रोजेक्ट में अपनी पोर्टेबल क्लास लाइब्रेरी की अन्य एक्सटेंशन विधियों का उपयोग करें। आपके यूडब्ल्यूपी एप्लिकेशन में भी उसी पोर्टेबल लाइब्रेरी का उपभोग किया जाएगा।
इस अध्याय में, हम चर्चा करेंगे कि आपके पुस्तकालय के संदर्भ कैसे जोड़े जाएं। लायब्रेरी में संदर्भ जोड़ना आपके अन्य प्रोजेक्ट्स के संदर्भ जोड़ने जैसा है, जैसे कंसोल प्रोजेक्ट और UWP प्रोजेक्ट।
अब आप देख सकते हैं कि पीसीएल परियोजना में डिफ़ॉल्ट रूप से कुछ संदर्भ हैं। आप अपने आवेदन की जरूरत के अनुसार अन्य संदर्भ भी जोड़ सकते हैं।
पीसीएल लाइब्रेरी में, आप प्रोजेक्ट.जॉन फ़ाइल भी देख सकते हैं।
{
"supports": {},
"dependencies": {
"NETStandard.Library": "1.6.0",
"Microsoft.NETCore.Portable.Compatibility": "1.0.1"
},
"frameworks": {
"netstandard1.3": {}
}
}
अपने पुस्तकालय में संदर्भ जोड़ने का एक तरीका यह है कि इसे सीधे प्रोजेक्ट में लिखें। json फ़ाइल। जैसा कि आप देख सकते हैं कि हमने निर्भरता अनुभाग के तहत कुछ संदर्भ जोड़े हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।
{
"supports": {},
"dependencies": {
"NETStandard.Library": "1.6.0",
"Microsoft.NETCore.Portable.Compatibility": "1.0.1",
"System.Runtime.Serialization.Json": "4.0.3",
"Microsoft.EntityFrameworkCore": "1.1.0"
},
"frameworks": {
"netstandard1.3": {}
}
}
आइए अब इस फाइल को सेव करते हैं और आप देखेंगे कि आपके लाइब्रेरी में अब रेफरेंस जोड़े गए हैं।
अपने पुस्तकालय में संदर्भ जोड़ने की अन्य विधि नुगेट पैकेज मैनेजर है। अब हमें राइट-क्लिक करेंStringLibrary (Portable) परियोजना और चयन करें Mange NuGet Packages…
ब्राउज़ टैब पर, आप किसी भी NuGet पैकेज को खोज सकते हैं; हमें कहते हैं कि हम "System.Runtime.Serialization.Primatics" पैकेज जोड़ना चाहते हैं।
दबाएं Install बटन, जो निम्न स्क्रीन प्रदर्शित करेगा।
अब, क्लिक करें OK बटन।
अंत में, क्लिक करें I Acceptइस NuGet पैकेज की स्थापना शुरू करने के लिए बटन। एक बार स्थापना समाप्त हो गई है, तो आप देखेंगे कि "System.Runtime.Serialization.Primatics" NuGet पैकेज आपके पुस्तकालय में जोड़ा जाता है।
इस अध्याय में, हम चर्चा करेंगे कि आपकी लाइब्रेरी को कैसे साझा किया जाए NuGet Packageताकि किसी अन्य परियोजना के भीतर इसका उपभोग किया जा सके। पैकेज बनाना उस कोड से शुरू होता है, जिसे आप अपने संगठन के भीतर सार्वजनिक nuget.org गैलरी या एक निजी गैलरी के माध्यम से पैकेज करना और दूसरों के साथ साझा करना चाहते हैं। पैकेज में अतिरिक्त फ़ाइलें भी शामिल हो सकती हैं जैसे कि एreadme यह प्रदर्शित किया जाता है जब पैकेज स्थापित होता है, और कुछ प्रोजेक्ट फ़ाइलों में परिवर्तन शामिल कर सकते हैं।
आइए अब एक सरल उदाहरण पर विचार करें जिसमें हम अपने पुस्तकालय से एक NuGet पैकेज बनाएंगे। ऐसा करने के लिए, कमांड प्रॉम्प्ट खोलें और उस फ़ोल्डर पर जाएं जहां आपके लाइब्रेरी प्रोजेक्ट का प्रोजेक्ट.जसन फ़ाइल स्थित है।
अब हम निम्नलिखित कमांड चलाते हैं।
dotnet help
अंत में, आप नए, पुनर्स्थापना और निर्माण आदि जैसे विभिन्न कमांड देख सकते हैं।
आखिरी आज्ञा है pack;यह एक NuGet पैकेज बनाएगा। अब हम निम्नलिखित कमांड को निष्पादित करते हैं।
dotnet pack
अब आप देख सकते हैं कि बिन फ़ोल्डर में NuGet संकुल का उत्पादन किया जाता है; हमें बिन \ डीबग फ़ोल्डर खोलने दें।
अब सवाल यह है कि NuGet पैकेज के अंदर क्या है, यह देखने के लिए कि हम NuGet पैकेज एक्सप्लोरर का उपयोग कर सकते हैं। आइये अब NuGet Package Explorer को खोलें।
पहला विकल्प चुनें Open a local package।
को चुनिए StringLibrary.1.0.0.nupkg और क्लिक करें Open।
आप देख सकते हैं कि पैकेज सामग्री अनुभाग में हमारे पास केवल StringLibrary.dll है। पैकेज मेटाडेटा अनुभाग में, आपको इस लाइब्रेरी के बारे में थोड़ी जानकारी दिखाई देगी, जैसे कि आईडी, संस्करण और सभी निर्भरताएँ।
अब हम खुलते हैं StringLibrary.1.0.0.symbols.nupkg।
इस NuGet पैकेज में, आप स्रोत फ़ाइलें और देखेंगे *.pdbसाथ ही फाइल करें। यदि आप पर डबल क्लिक करते हैंStringLib.cs फ़ाइल, आप स्रोत कोड के रूप में अच्छी तरह से देखते हैं।
यहां सवाल यह है कि मेटाडेटा को कैसे कॉन्फ़िगर किया जा सकता है जैसे संस्करण, लेखक और विवरण, आदि।
Project.json फ़ाइल का उपयोग प्रोजेक्ट मेटाडेटा, संकलन जानकारी और निर्भरता को परिभाषित करने के लिए .NET कोर परियोजनाओं पर किया जाता है। आइए अब हम प्रोजेक्ट खोलते हैं। Json फाइल खोलें और निम्नलिखित अतिरिक्त जानकारी जोड़ें।
{
"authors": [ "Mark Junior" ],
"description": "String Library API",
"version" : "1.0.1-*",
"supports": {},
"dependencies": {
"Microsoft.EntityFrameworkCore": "1.1.0",
"Microsoft.NETCore.Portable.Compatibility": "1.0.1",
"NETStandard.Library": "1.6.0",
"System.Runtime.Serialization.Json": "4.0.3",
"System.Runtime.Serialization.Primitives": "4.3.0"
},
"frameworks": {
"netstandard1.3": {}
}
}
अब आप लेखक का नाम, विवरण और संस्करण जैसी अतिरिक्त जानकारी यहाँ देख सकते हैं। आइए हम इस फ़ाइल को सहेजते हैं, लाइब्रेरी प्रोजेक्ट बनाते हैं, फिर "डॉटनेट पैक" कमांड को फिर से निष्पादित करते हैं।
बिन \ डीबग फ़ोल्डर के अंदर, आप देख सकते हैं कि स्ट्रिंगलिफ्ट नूगेट पैकेज संस्करण 1.0.1 के साथ निर्मित हैं; आइए हम इसे NuGet Package Explorer में खोलें।
आप अद्यतन मेटाडेटा देखेंगे। अब सवाल यह है कि हम इसे दूसरे पैकेज में कैसे इस्तेमाल कर सकते हैं।
हमें नुगेट फ़ीड में कहीं प्रकाशित करके शुरू करने की आवश्यकता है और फिर हम किसी अन्य परियोजना में इसका उपभोग कर सकते हैं।
अद्यतन मेटाडेटा प्रकाशित करने के लिए दो विकल्प हैं -
- इसे nuget.org पर प्रकाशित करें
- मेटाडेटा को निजी NuGet फ़ीड में पुश करें
यहां हम निजी NuGet फ़ीड का उपयोग करेंगे क्योंकि यह nuget.org पर किसी खाते को सेटअप करने की तुलना में बहुत आसान है। अपने पैकेज को nuget.org पर प्रकाशित करने का तरीका जानने के लिए, आप यहाँ निर्दिष्ट सभी दिशानिर्देशों का पालन कर सकते हैंhttps://docs.microsoft.com/en-us/nuget/create-packages/publish-a-package।
अपडेट किए गए मेटाडेटा को निजी NuGet फ़ीड में धकेलने के लिए इन चरणों का पालन करें।
Step 1- साथ शुरू करने के लिए, हमें नगेट कमांडलाइन उपयोगिता की आवश्यकता है और हमें इसे स्थापित करना होगा। आइए अब हम NuGet पैकेज मैनेजर खोलें और nuget.commandline को खोजें।
Step 2 - Nuget.Commandline चुनें और क्लिक करें Install।
Step 3 - क्लिक करें OKNuget.Commandline स्थापित करने के लिए। आप इसे निम्न यूआरएल से मैन्युअल रूप से डाउनलोड करके भी स्थापित कर सकते हैंhttps://dist.nuget.org/index.html और फिर पर्यावरण चर सेट करें।
Step 4 - इंस्टॉलेशन समाप्त होने के बाद, हम कमांड प्रॉम्प्ट को फिर से खोलते हैं और इंस्टॉलेशन पर जाते हैं bin\Debug फ़ोल्डर जहां NuGet पैकेज स्थित हैं और निम्नलिखित कमांड निर्दिष्ट करते हैं -
nuget add StringLibrary.1.0.1.nupkg -Source D:\PrivateNugetPackages
Step 5 - उपरोक्त कमांड में, हम StringLibrary.1.0.1.nupkg पैकेज को अपनी निजी फ़ीड में जोड़ते हैं और स्थान है D:\PrivateNugetPackages-Source पैकेज स्रोत को निर्दिष्ट करता है।
Step 6 - आप देख सकते हैं कि StringLibraryस्थापित है; StringLibrary आगे निजी फ़ीड में जोड़ा जा सकता है।
Step 7 - आइए हम उस फोल्डर में जाते हैं।
Step 8 - अंदर stringlibrary फ़ोल्डर, आपको संस्करण नाम के साथ एक और फ़ोल्डर दिखाई देगा और यहां यह 1.0.1 है।
NuGet पैकेज यहां स्थित है।
इस अध्याय में, हम चर्चा करेंगे कि नूगेट पैकेज का उपभोग कैसे करें जो हमने एक निजी नुगेट फ़ीड में बनाया और प्रकाशित किया है। इसलिए, पहले हम एक Xamarin.Forms प्रोजेक्ट बनाएंगे। हमें सबसे पहले यह समझने की जरूरत है कि Xamarin क्या है।
Xamarin.Forms एक ऐसा ढांचा है जो डेवलपर्स को तेजी से क्रॉसप्लेट रिकॉर्डर यूजर इंटरफेस बनाने की अनुमति देता है।
Xamarin.Forms एक क्रॉस-प्लेटफॉर्म है जो मूल रूप से समर्थित UI टूलकिट एब्स्ट्रैक्शन है जो डेवलपर्स को आसानी से उपयोगकर्ता इंटरफेस बनाने की अनुमति देता है जिसे एंड्रॉइड, आईओएस, विंडोज और विंडोज फोन में साझा किया जा सकता है।
उपयोगकर्ता इंटरफ़ेस को लक्ष्य प्लेटफ़ॉर्म के मूल नियंत्रणों का उपयोग करके प्रदान किया जाता है, जिससे Xamarin.Forms एप्लिकेशन को प्रत्येक प्लेटफ़ॉर्म पर उपयुक्त रूप और दृश्यता बनाए रखने की अनुमति देता है।
Xamarin.Forms को शुरू करने के लिए, हमें Visual Studio 2015 में कुछ अतिरिक्त सुविधाओं की आवश्यकता है। आइए हम आपके Visual Studio 2015 को संशोधित करते हैं और सुनिश्चित करते हैं कि निम्न क्रॉस-प्लेटफ़ॉर्म मोबाइल विकास विकल्प चुना गया है।
एक बार इंस्टॉलेशन समाप्त होने के बाद, Xamarin को सिलेक्ट करके अपडेट करें Tools → Options…
नीचे स्क्रॉल करें और बाएँ फलक में Xamarin का विस्तार करें और फिर चयन करें Other। डायलॉग बॉक्स के ऊपरी दाएं कोने पर, क्लिक करेंCheck Now यह देखने के लिए कि क्या अपडेट उपलब्ध हैं।
आप देख सकते हैं कि अपडेट उपलब्ध हैं, हम पर क्लिक करते हैं Downloadडाउनलोड शुरू करने के लिए बटन। एक बार डाउनलोड पूरा होने के बाद, आपको अपडेट इंस्टॉल करने के लिए सूचित किया जाएगा।
आइए अब हम विजुअल स्टूडियो को फिर से खोलें और चुनें File → New → Project… मेनू विकल्प।
बाएँ फलक में, का चयन करें Visual C# → Cross-Platform टेम्पलेट और मध्य फलक में, का चयन करें Blank Xaml App (Xamarin.Forms Portable)। नाम फ़ील्ड में नाम दर्ज करें और ठीक पर क्लिक करें।
लक्ष्य संस्करण और न्यूनतम संस्करण का चयन करें और ठीक पर क्लिक करें।
आप परियोजनाओं की एक श्रृंखला देखेंगे; शीर्ष पर हमारे पास PCL लाइब्रेरी है, जो Android, iOS, UWP, Windows 8.1 और Windows Phone 8.1 जैसे सभी प्लेटफार्मों के बीच साझा की जाएगी।
यहां, हम पीसीएल लाइब्रेरी पर ध्यान केंद्रित करेंगे और यहां कुछ कोड लाएंगे। कोड का विस्तार करते हैं।
इस Xamarin.Forms टेम्पलेट में, आप जेनेरिक App.xaml और MainPage.xaml देख सकते हैं, Xamarin.Forms XAML फ्रेमवर्क का उपयोग करता है जो इन प्लेटफार्मों में काम करता है।
हमें अपने कोड आयात करने की आवश्यकता है और हमें पिछले अध्याय में स्थापित निजी नुगेट फ़ीड की भी आवश्यकता है।
आइये अब हम NuGet Package Manager को खोलते हैं। पैकेज स्रोत ड्रॉपडाउन सूची के आगे वाले व्हील पर क्लिक करें।
हमें यहां अपना निजी फ़ीड जोड़ने की आवश्यकता है, हम पर क्लिक करते हैं plus (+) button।
आप देखेंगे कि एक और चेकबॉक्स जोड़ा गया है Available package sources अनुभाग, हमें एक नाम और स्रोत पथ निर्दिष्ट करें और क्लिक करें OK।
आइए अब ब्राउज़ टैब पर जाएं और पैकेज स्रोत ड्रॉपडाउन सूची से PrivateSource का चयन करें और आप स्ट्रिंगरोलॉग्स NuGem पैकेज देखेंगे। StringLibrary का चयन करें और क्लिक करेंInstall।
ठीक पर क्लिक करें और आपको एक त्रुटि दिखाई देगी।
हम .NETPortable प्रोफ़ाइल संस्करण 259 के साथ लाइब्रेरी का उपयोग नहीं कर सकते, हम अगले अध्याय में इस त्रुटि को ठीक कर देंगे।
इस अध्याय में, हम Xamarin.Forms परियोजना में हमारे निजी फ़ीड से NuGet पैकेज स्थापित करते समय हमें मिली त्रुटि को ठीक कर देंगे।
हम आगे संक्षेप में समस्या को समझेंगे। आरंभ करने के लिए, हमें PCL लाइब्रेरी पर राइट-क्लिक करें और गुण चुनें।
इस पृष्ठ पर, आपको लक्षित श्रृंखलाओं की पूरी श्रृंखला दिखाई देगी। त्रुटि से, आप देख सकते हैं कि .NETPortable प्रोफाइल 259 हमारे StringLibrary 1.0.1 के साथ संगत नहीं है। हालाँकि, यह .NET मानक 1.1 पुस्तकालय से संदर्भ लेने की कोशिश कर रहा है।
आइए अब .NET स्टैंडर्ड लाइब्रेरी देखें और यह पहचानें कि कौन सा प्लेटफ़ॉर्म हमारी लाइब्रेरी के अनुकूल नहीं है।
आप देख सकते हैं कि विंडोज फोन सिल्वरलाइट 8 .NET मानक 1.0 के साथ संगत है। यदि आप निम्न वेबपृष्ठ खोलते हैं, तो आप देखेंगे कि Profile259 केवल .NET मानक 1.0 का समर्थन कर सकता है।
आइए अब विंडोज फोन सिल्वरलाइट 8 को अनचेक करें।
दबाएं OK बटन।
अब इस समस्या को ठीक करने के लिए ठीक पर क्लिक करें और परिवर्तन लक्ष्य संवाद को रद्द करें और फिर पैकेज प्रबंधक कंसोल खोलें और निम्न कमांड निष्पादित करें।
PM > Uninstall-Package Xamarin.Forms
आइए अब पीसीएल लाइब्रेरी के गुणों पर जाएं। चेंज बटन पर क्लिक करें।
विंडोज फोन सिल्वरलाइट 8 को अनचेक करें और ओके पर क्लिक करें।
अब आप देख सकते हैं कि विंडोज फोन सिल्वरलाइट 8 टारगेटेड फ्रेमवर्क में उपलब्ध नहीं है। आप वह प्रोफ़ाइल भी देख सकते हैं जो अभी लक्ष्य है। इसे देखने के लिए, आइए हम PCL लाइब्रेरी को अनलोड करें और XamarinApp.csproj फ़ाइल को संपादित करें।
अब आप देख सकते हैं कि TargetFrameworkProfile अब Profile111 है।
यदि आप दस्तावेज़ खोलते हैं, तो आप देखेंगे कि Profile111 .NET मानक 1.1 का समर्थन कर रहा है।
चलिए अब PCL को फिर से लोड करते हैं और NuGet Package Manager को खोलते हैं और निजी फीड से StringLibrary पैकेज को स्थापित करने का प्रयास करते हैं।
निर्भरता व्यवहार ड्रॉपडाउन सूची से, निर्भरता पर ध्यान न दें का चयन करें और फिर क्लिक करें Install।
आप देख सकते हैं कि StringLibrary पैकेज अब निजी फ़ीड से स्थापित है। यदि आप पीसीएल के संदर्भों का विस्तार करते हैं, तो आप देखेंगे कि स्ट्रिंगरोलुलेट्स संदर्भ भी नीचे दिखाए गए अनुसार जोड़ा गया है।
हमने विंडोज फोन सिल्वरलाइट 8 मुद्दे के लिए Xamarin.Forms की स्थापना रद्द कर दी थी। Xamarin.Forms को फिर से स्थापित करने की आवश्यकता है। यह अनुशंसा की जाती है कि एक ही संस्करण स्थापित हो।
एक बार इंस्टॉलेशन पूरा हो जाने के बाद, हम अपने ऐप्लिकेशन में StringLibrary कार्यक्षमता का उपयोग करते हैं।
इस अध्याय में, हम चर्चा करेंगे कि .NET कोर का उपयोग करके परीक्षण परियोजना कैसे बनाई जाए। इकाई परीक्षण सॉफ्टवेयर के लिए एक विकास प्रक्रिया है जिसमें किसी अनुप्रयोग के सबसे छोटे परीक्षण योग्य भाग होते हैं, जिन्हें इकाई कहा जाता है। वे किसी भी उचित संचालन के लिए व्यक्तिगत रूप से और स्वतंत्र रूप से जांच की जाती हैं। इकाई परीक्षण या तो स्वचालित या मैन्युअल रूप से भी किया जा सकता है।
अब न्यू प्रोजेक्ट डायलॉग बॉक्स खोलें और चुनें Visual C# → .NET Core टेम्पलेट।
इस संवाद बॉक्स पर, आप देख सकते हैं कि इकाई परीक्षण के लिए कोई परियोजना टेम्पलेट नहीं है। एक इकाई परीक्षण परियोजना बनाने के लिए, हमें कमांड लाइन उपयोगिता का उपयोग करना चाहिए। हमारे द्वारा बनाए गए समाधान फ़ोल्डर पर जाएं; टेस्ट फोल्डर बनाएं और टेस्ट फोल्डर के अंदर एक और फोल्डर बनाएं और उसे कॉल करेंStringLibraryTests।
आइए अब निम्नलिखित कमांड को निष्पादित करके एक नई परीक्षण परियोजना बनाने के लिए डॉटनेट कमांडलाइन उपयोगिता का उपयोग करें -
dotnet new -t xunittest
अब आप देख सकते हैं कि एक नया C # प्रोजेक्ट बनाया गया है; आइए फोल्डर को निष्पादित करके देखेंv कमांड और आप देखेंगे project.json तथा Tests.cs फ़ाइलों को नीचे दिखाया गया है।
यहाँ project.json फ़ाइल में कोड है।
{
"version": "1.0.0-*",
"buildOptions": {
"debugType": "portable"
},
"dependencies": {
"System.Runtime.Serialization.Primitives": "4.1.1",
"xunit": "2.1.0",
"dotnet-test-xunit": "1.0.0-rc2-192208-24"
},
"testRunner": "xunit",
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
}
},
"imports": [
"dotnet5.4",
"portable-net451+win8"
]
}
}
}
निम्नलिखित Test.cs फ़ाइल में कोड है।
using System;
using Xunit;
namespace Tests {
public class Tests {
[Fact]
public void Test1() {
Assert.True(true);
}
}
}
NuGet से आवश्यक निर्भरता प्राप्त करने के लिए, हमें निम्नलिखित कमांड निष्पादित करें -
dotnet restore
हम परीक्षण चला सकते हैं जब आवश्यक निर्भरता बहाल हो जाती है।
आप देख सकते हैं कि संकलन सफल हुआ; जैसा कि आप नीचे जाते हैं, आप निष्पादित परीक्षा के बारे में कुछ जानकारी देख सकते हैं।
वर्तमान में हमारे पास 1 परीक्षण निष्पादित किया गया है, 0 त्रुटि, 0 विफल, 0 छोड़ दिया गया है और निष्पादन प्रक्रिया द्वारा लिए गए समय को भी जानकारी के रूप में उल्लेख किया गया है।
इस अध्याय में, हम चर्चा करेंगे कि विज़ुअल स्टूडियो में परीक्षण कैसे चलाएं। .NET कोर को परीक्षण क्षमता को ध्यान में रखकर डिजाइन किया गया है, ताकि आपके अनुप्रयोगों के लिए यूनिट टेस्ट बनाना पहले से कहीं अधिक आसान हो। इस अध्याय में, हम विजुअल स्टूडियो में अपने परीक्षण प्रोजेक्ट को चलाएंगे और निष्पादित करेंगे।
हमें Visual Studio में FirstApp समाधान खोलें।
आप देख सकते हैं कि इसकी केवल दो परियोजनाएँ हैं और आप परीक्षण परियोजना को नहीं देख पाएंगे क्योंकि हमने उस परियोजना को अपने हल में नहीं जोड़ा है।
आइए हम पहले एक फ़ोल्डर जोड़ते हैं और इसे कॉल करते हैं test।
पर राइट क्लिक करें test फ़ोल्डर।
चुनते हैं project.json फ़ाइल और क्लिक करें Open।
निम्न स्क्रीनशॉट में कोड दिखाया गया है Tests.cs आउटपुट के रूप में फ़ाइल करें।
यह डिफ़ॉल्ट कार्यान्वयन है और यह केवल परीक्षण कर रहा है कि ट्रू सच के बराबर है। यह xUnit परीक्षण ढाँचा है और आप उस फैक्ट विशेषता को देखेंगे जो परीक्षण विधि को एनोटेट और निरूपित करती है।
using System;
using Xunit;
namespace Tests {
public class Tests {
[Fact]
public void Test1() {
Assert.True(true);
}
}
}
निम्नलिखित का कार्यान्वयन है project.json फ़ाइल।
{
"version": "1.0.0-*",
"buildOptions": {
"debugType": "portable"
},
"dependencies": {
"System.Runtime.Serialization.Primitives": "4.1.1",
"xunit": "2.1.0",
"dotnet-test-xunit": "1.0.0-rc2-192208-24"
},
"testRunner": "xunit",
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
}
},
"imports": [
"dotnet5.4",
"portable-net451+win8"
]
}
}
}
में project.jsonफ़ाइल, परीक्षण ढांचे के लिए सबसे महत्वपूर्ण निर्भरता xunit है, जो तथ्य विशेषता में लाता है। यह xunit के साथ परीक्षण के लिए परीक्षण ढांचे और एपीआई में लाता है।
हमारे पास भी है dotnet-test-xunit, यह एक अपनाने वाला है ताकि xunit .NET कोर के साथ काम कर सके, विशेष रूप से साथ dotnet testकमांड लाइन उपयोगिता। फिर आप देखेंगेtestRunner जो xunit चलेगा और आप भी देख सकते हैं netcoreapp1.0 ढांचा।
आपको नीचे .NETCore.App निर्भरता दिखाई देगी।
Visual Studio में परीक्षण चलाने के लिए, हम से एक्सप्लोरर खोलें Test → Window → Test Explorer मेनू विकल्प।
और आप देख सकते हैं कि विज़ुअल स्टूडियो स्वचालित रूप से परीक्षण का पता लगाता है। परीक्षण के नाम के होते हैंnamespace.className.TestMethodName। अब हम पर क्लिक करते हैंRun All button in Test Explorer।
यह पहली बार कोड और टेस्ट को बनाएगा और आपको परीक्षण द्वारा लिया गया कुल समय दिखाई देगा। आइए हम परीक्षण पद्धति को बदलते हैं ताकि परीक्षण विफल होने पर हम आउटपुट देख सकें।
using System;
using Xunit;
namespace Tests {
public class Tests {
[Fact]
public void Test1() {
Assert.True(false);
}
}
}
आइए हम फिर से परीक्षण पर क्लिक करें Run All बटन लिंक।
अब आप देख सकते हैं test विफलता।
इस अध्याय में, हम अपने स्ट्रिंगलिंक का परीक्षण करेंगे और ऐसा करने के लिए, हमें अपनी परियोजनाओं को पुनर्व्यवस्थित करने की आवश्यकता है ताकि हम डिफ़ॉल्ट हस्तक्षेप का पालन कर सकें।
हमें खुलने दो global.json फ़ाइल।
{
"projects": [ "src", "test" ],
"sdk": {
"version": "1.0.0-preview2-003131"
}
}
इस फ़ाइल के शीर्ष पर आपको प्रोजेक्ट सेटिंग्स दिखाई देंगी और यह कुछ फ़ोल्डर सेट करता है जैसे कि src तथा test डिफ़ॉल्ट रूप से।
अधिवेशन के अनुसार, हमारे पास इन फ़ोल्डरों में परियोजनाएँ होनी चाहिए, यह नया सम्मेलन है और इसका उपयोग .NET कोर के भाग के रूप में किया जाएगा।
समाधान एक्सप्लोरर में, आप देख सकते हैं कि कंसोल प्रोजेक्ट और लाइब्रेरी प्रोजेक्ट दोनों अंदर हैं src परीक्षण परियोजना के अंदर फ़ोल्डर है test फ़ोल्डर।
और समाधान एक्सप्लोरर में प्रोजेक्ट संरचना का प्रतिनिधित्व नहीं करता है जहां डिस्क पर प्रोजेक्ट भौतिक रूप से मौजूद हैं। अब हम सॉल्यूशन फोल्डर को ओपन करते हैं और आप देखेंगेStringLibrary परियोजना अंदर नहीं है src फ़ोल्डर।
आप देख सकते हैं कि दोनों src तथा test में निर्दिष्ट कन्वेंशन के लिए फ़ोल्डर्स मैप global.jsonफ़ाइल। हालाँकि, हमारे पास एक प्रोजेक्ट स्ट्रिंगलिंउड है जो सम्मेलन से बाहर है। अब हम जोड़ते हैंStringLibrary अंदर परियोजना src फ़ोल्डर।
Src फ़ोल्डर में, हमारे पास दो प्रोजेक्ट्स हैं और हमें समस्या को ठीक करने की आवश्यकता है ताकि हम सभी प्रोजेक्ट्स का सही उपयोग कर सकें। आइए हम विजुअल स्टूडियो में वापस जाएं और स्ट्रिंगरिंग्स प्रोजेक्ट पर राइट-क्लिक करें और निकालें विकल्प चुनें। यह इसे हटा नहीं देगा, लेकिन यह केवल परियोजना को हटा देगा।
अब src फोल्डर पर राइट क्लिक करें और सेलेक्ट करें Add → Existing Project…
StringLibrary प्रोजेक्ट के लिए ब्राउज़ करें जो अब अंदर है src फ़ोल्डर, का चयन करें StringLibrary.csproj फ़ाइल और क्लिक करें Open।
अब हमें इसका संदर्भ हटाना होगा StringLibrary वहाँ से project.json कंसोल ऐप की फ़ाइल।
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
},
"NuGet.CommandLine": "3.5.0",
"System.Runtime.Serialization.Json": "4.0.3"
},
"frameworks": {
"netcoreapp1.0": {
"dependencies": { },
"imports": "dnxcore50"
}
}
}
परिवर्तनों को सहेजें और फिर एक संदर्भ जोड़ें StringLibrary फिर से अपने कंसोल प्रोजेक्ट में।
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
},
"NuGet.CommandLine": "3.5.0",
"System.Runtime.Serialization.Json": "4.0.3"
},
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
"StringLibrary": {
"target": "project"
}
},
"imports": "dnxcore50"
}
}
}
अब सब कुछ फिर से काम करना चाहिए और आप निर्माण कर सकते हैं StringLibrary और फिर FirstApp(कंसोल प्रोजेक्ट) बिना किसी त्रुटि के। चलिए अब xunit का उपयोग करके StringLibrary कार्यक्षमता का परीक्षण करते हैं। हमें अपने परीक्षण प्रोजेक्ट में StringLibrary का संदर्भ जोड़ना होगा। StringLibraryTests प्रोजेक्ट के संदर्भ पर राइट-क्लिक करें और संदर्भ जोड़ें ...
क्लिक OK जो एक संदर्भ जोड़ देगा StringLibraryहमारे परीक्षण परियोजना के लिए। अब हम निम्नलिखित कोड को बदल देते हैंTests.cs फ़ाइल।
using System;
using Xunit;
using StringLibrary;
namespace Tests {
public class Tests {
[Fact]
public void StartsWithUpperCaseTest() {
string input = "Mark";
Assert.True(input.StartsWithUpper());
}
[Fact]
public void StartsWithLowerCaseTest() {
string input = "mark";
Assert.True(input.StartsWithLower());
}
[Fact]
public void StartsWithNumberCaseTest() {
string input = "123";
Assert.True(input.StartsWithNumber());
}
}
}
आप देख सकते हैं कि हमारे पास तीन परीक्षण विधियां हैं जो स्ट्रिंगलिंग की कार्यक्षमता का परीक्षण करेंगे। हमें क्लिक करेंRun All लिंक और आप परीक्षण एक्सप्लोरर में निम्न आउटपुट देखेंगे।
आप कमांड लाइन से परीक्षण भी चला सकते हैं। हमें कमांड प्रॉम्प्ट खोलें और निष्पादित करेंdotnet test आदेश।
इस अध्याय में, हम प्रबंधित एक्सटेंसीबिलिटी फ्रेमवर्क (MEF) पर चर्चा करेंगे। MEF का उपयोग तीसरे पक्ष के प्लगइन एक्स्टेंसिबिलिटी के लिए किया जा सकता है, या यह नियमित अनुप्रयोगों के लिए शिथिल-युग्मित प्लग-इन आर्किटेक्चर के लाभों को ला सकता है।
MEF हल्के, एक्स्टेंसिबल एप्लिकेशन बनाने के लिए एक पुस्तकालय है।
यह एप्लिकेशन डेवलपर्स को उन एक्सटेंशनों की खोज करने और उपयोग करने की अनुमति देता है जिनमें कोई कॉन्फ़िगरेशन आवश्यक नहीं है।
MEF .NET फ्रेमवर्क 4 का एक अभिन्न अंग है, और जहां भी .NET फ्रेमवर्क का उपयोग किया जाता है वह उपलब्ध है जो बड़े अनुप्रयोगों के लचीलेपन, स्थिरता और परीक्षणशीलता में सुधार करता है।
आप अपने क्लाइंट अनुप्रयोगों में MEF का उपयोग कर सकते हैं, चाहे वे Windows Forms, WPF, या किसी अन्य तकनीक का उपयोग करें, या ASP.NET के साथ सर्वर अनुप्रयोगों में।
MEF के रूप में चित्रित किया गया है Microsoft.Composition .NET कोर के रूप में अच्छी तरह से लेकिन आंशिक रूप से।
केवल System.Composition पोर्ट किया गया है, और System.ComponentModel.Compositionअभी तक उपलब्ध नहीं है। इसका मतलब है, हमारे पास कैटलॉग नहीं हैं जो एक निर्देशिका में असेंबली से प्रकार लोड कर सकते हैं।
इस अध्याय में, हम केवल सीखेंगे कि हम .NET कोर एप्लीकेशन में MEF का उपयोग कैसे कर सकते हैं।
आइए एक सरल उदाहरण को समझते हैं जिसमें हम .NET कोर कंसोल एप्लिकेशन में MEF का उपयोग करेंगे। अब एक नया .NET कोर कंसोल प्रोजेक्ट बनाते हैं।
बाएँ फलक में, का चयन करें Templates → Visual C# → .NET कोर और फिर मध्य फलक में, कंसोल एप्लिकेशन (.NET कोर) का चयन करें।
नाम फ़ील्ड में प्रोजेक्ट का नाम दर्ज करें और ठीक पर क्लिक करें।
प्रोजेक्ट बनने के बाद, हमें Microsoft.Composition का संदर्भ जोड़ना होगा ताकि हम MEF का उपयोग कर सकें। ऐसा करने के लिए, हमें समाधान एक्सप्लोरर में प्रोजेक्ट पर राइट-क्लिक करें औरManage NuGet Packages…
निम्न को खोजें Microsoft.Composition और क्लिक करें Install।
दबाएं OK बटन।
दबाएं I Accept बटन।
जब स्थापना पूरी हो जाती है, तो आपको संदर्भ में एक त्रुटि मिलेगी।
हमें खुलने दो project.json फ़ाइल।
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.Composition": "1.0.30",
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
}
},
"frameworks": {
"netcoreapp1.0": {
"imports": "dnxcore50"
}
}
}
आप देख सकते हैं कि Microsoft.Composition निर्भरता को जोड़ा जाता है, लेकिन समस्या यह है कि यह पैकेज संगत नहीं है dnxcore50। इसलिए हमें आयात करने की आवश्यकता हैportablenet45+win8+wp8+wpa81। चलिए अब हम आपकी जगह लेते हैंproject.json निम्नलिखित कोड के साथ फ़ाइल।
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.Composition": "1.0.30",
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
}
},
"frameworks": {
"netcoreapp1.0": {
"imports": "portable-net45+win8+wp8+wpa81"
}
}
}
इस फ़ाइल को सहेजें और आप देखेंगे कि त्रुटि ठीक हो गई है।
यदि आप सन्दर्भ का विस्तार करते हैं, तो आपको एक संदर्भ दिखाई देगा Microsoft.Composition।
पहले हमें एक इंटरफ़ेस बनाने की ज़रूरत है जिसे निर्यात किया जाए और इंटरफ़ेस को लागू किया जाए और निर्यात विशेषता के साथ वर्ग को सजाया जाए। आइए अब हम एक नया वर्ग जोड़ते हैं।
नाम फ़ील्ड में अपनी कक्षा के लिए नाम दर्ज करें और क्लिक करें Add।
हमें निम्नलिखित कोड जोड़ते हैं PrintData.cs फ़ाइल।
using System;
using System.Collections.Generic;
using System.Composition;
using System.Linq;
using System.Threading.Tasks;
namespace MEFDemo {
public interface IPrintData {
void Send(string message);
}
[Export(typeof(IPrintData))]
public class PrintData : IPrintData {
public void Send(string message) {
Console.WriteLine(message);
}
}
}
जैसा कि ऊपर बताया गया है, कैटलॉग Microsoft.Composition नामस्थान में उपलब्ध नहीं हैं। इसलिए, यह असेंबली से सभी प्रकारों को निर्यात विशेषता के साथ लोड करेगा और आयात विशेषता को संलग्न करेगा जैसा कि प्रोग्राम .cs फ़ाइल में कंपोज़ विधि में दिखाया गया है।
using System;
using System.Collections.Generic;
using System.Composition;
using System.Composition.Hosting;
using System.Linq;
using System.Reflection;
using System.Threading.Tasks;
namespace MEFDemo {
public class Program {
public static void Main(string[] args) {
Program p = new Program();
p.Run();
}
public void Run() {
Compose();
PrintData.Send("Hello,this is MEF demo");
}
[Import]
public IPrintData PrintData { get; set; }
private void Compose() {
var assemblies = new[] { typeof(Program).GetTypeInfo().Assembly };
var configuration = new ContainerConfiguration()
.WithAssembly(typeof(Program).GetTypeInfo().Assembly);
using (var container = configuration.CreateContainer()) {
PrintData = container.GetExport<IPrintData>();
}
}
}
}
आइए अब हम आपके एप्लिकेशन को चलाते हैं और आप देखेंगे कि यह इंस्टेंटिमिटिंग द्वारा चल रहा है PrintData कक्षा।
MEF के बारे में अधिक जानने के लिए, हम निम्नलिखित यूआरएल पर जाएँ https://msdn.microsoft.com/en-us/library/dd460648%28v=vs.110%29.aspx अधिक जानकारी के लिए।
इस अध्याय में, हम .NET कोर में आगामी सुविधाओं को समझेंगे। हम ब्राउज़र में निम्नलिखित यूआरएल खोलकर .NET कमांड लाइन टूल्स के साथ शुरू करेंगेhttps://github.com/dotnet/cli
प्रगति के बारे में अधिक जानने के लिए, आप नीचे स्क्रॉल करके .NET कोर एसडीके के नवीनतम संस्करण को डाउनलोड कर सकते हैं और आपको इंस्टॉलर और बायनेरी अनुभाग दिखाई देगा।
आप विभिन्न ऑपरेटिंग सिस्टम के लिए पूर्वावलोकन टूल का नवीनतम संस्करण देख सकते हैं, आइए हम आपके ऑपरेटिंग सिस्टम के अनुसार इंस्टॉलर का चयन करें।
हम .NET कोर 2.0 के पूर्वावलोकन 1 पर काम कर रहे हैं।
आइए अब कमांड प्रॉम्प्ट को खोलकर हमारे वर्तमान टूलिंग को देखें और निम्नलिखित कमांड को निष्पादित करें।
dotnet --info
आप नीचे दिखाए गए अनुसार अपने सिस्टम पर वर्तमान में स्थापित .NET कमांड लाइन टूल्स के बारे में जानकारी देखेंगे।
आप देख सकते हैं कि वर्तमान में हमारे पास 2 टूलिंग का पूर्वावलोकन है। आइए अब हम निम्नलिखित कमांड को देखते हैंnew आदेश।
dotnet help new
प्रोजेक्ट की नई कमांड भाषा के लिए, आप C # और F # का चयन कर सकते हैं और प्रोजेक्ट का प्रकार, आदि।
आइए अब .NET कोर के नवीनतम संस्करण में परिवर्तन देखते हैं। इंस्टॉलर डाउनलोड हो जाने के बाद, इसे इंस्टॉल करने के लिए इस पर डबल-क्लिक करें। इंस्टॉल पर क्लिक करें।
निम्न स्क्रीनशॉट इंस्टॉलेशन प्रक्रिया को दर्शाता है।
यह स्थापना प्रक्रिया शुरू कर देगा। एक स्थापना समाप्त हो गई है, इस संवाद को बंद करें।
कमांड प्रॉम्प्ट खोलें और निम्न कमांड निष्पादित करें।
dotnet --info
आप नीचे दिखाए गए अनुसार अपने सिस्टम पर वर्तमान में स्थापित .NET कमांड लाइन टूल्स का जानकारी देखेंगे।
अब आप देख सकते हैं कि हमारे पास .NET Core 2 का प्रीव्यू 1 टूलींग है। चलिए अब कमांड कोड में निम्नलिखित कोड चलाते हैं। .NET Core 2 प्रीव्यू 1 में नए कमांड के बारे में देखें।
dotnet help new
कमांड आपको पैकेज कैश के साथ ही पैकेज डाउनलोड करने में मदद करता है।
कमांड निम्न वेबपेज को खोलता है जिसमें .NET कोर 2 प्रीव्यू 1 में नए कमांड के बारे में जानकारी है।
हमें नीचे स्क्रॉल करें, अब आप देख सकते हैं कि हम अधिक टेम्पलेट्स के साथ .NET कोर एप्लिकेशन बना सकते हैं।
अब हम बना सकते हैं mstest, web, mvc तथा webapi कमांड लाइन का उपयोग करने के साथ ही परियोजनाएं।
.NET Core ने Project.json को छोड़ने और MSBuild और * .csproj पर वापस जाने का निर्णय लिया है। यह कुछ ऐसा है जो पहले से ही जारी किया गया है। नेट कोर 2.0 प्रीव्यू 1 टूलिंग। यह काफी निराशाजनक है, क्योंकि प्रोजेक्ट.जसन में ताजी हवा की सांस थी। हालांकि, यह समझ में आता है और कई फायदे भी हैं।
आइए अब उन फायदों पर चर्चा करते हैं जो परिवर्तन लाता है -
यह मौजूदा विजुअल स्टूडियो सॉल्यूशंस के संक्रमण को सीधे .NET Core में बदल देगा।
यह एक बहुत बड़ा बदलाव है और यह MSBuild के आसपास CI / RM में मौजूदा निवेश का लाभ उठाने में सक्षम होगा।
MSBuild में निर्माण के दौरान, हम वृद्धिशील संकलन, बिल्डटाइम निर्भरता, कॉन्फ़िगरेशन प्रबंधन, आदि का समाधान करने के बारे में सोच सकते हैं।
डॉटनेट क्लि को समय पर जहाज करने के लिए बहुत सारे काम की आवश्यकता होती है, क्योंकि यह अब केवल ASP.NET Core के बारे में नहीं है, बल्कि एप्स, UWP एप्स आदि को भी सांत्वना देता है।
MSBuild और * .csproj में परिवर्तन निम्नलिखित हैं -
Project.json फ़ाइल (* .xproj) को MSBuild (* .csproj) द्वारा प्रतिस्थापित किया जाएगा।
Project.json में सुविधाएँ * .csproj में वापस मर्ज होने लगेंगी।
यह अभी तक स्पष्ट नहीं है कि वे संकुल सूची के बारे में क्या करने जा रहे हैं, लेकिन यह उल्लेख किया गया था कि वे इसे जस के तहत रख सकते हैं nuget.json या इसे मर्ज करें *.csproj।
माना जाता है कि विज़ुअल स्टूडियो का उपयोग करने पर संक्रमण चिकनी और संभावित स्वचालित होना चाहिए।
MSBuild के लाभ
MSBuild एक खुला स्रोत है और GitHub पर उपलब्ध है और यह पूरी तरह से क्रॉसप्लेट रिकॉर्डर बनने के लिए बाध्य है।
MSBuild नाटकीय रूप से की संरचना को सरल और ट्रिम करेगा *.csproj।
Microsoft एक नई परियोजना प्रणाली भी पेश कर रहा है, जो विज़ुअल स्टूडियो की आवश्यकता के बिना बहुत सारे परिदृश्यों को सक्षम कर सकती है और विवरण इस यूआरएल पर दिए गए हैं https://github.com/dotnet/roslyn-project-system/।
लक्ष्य यह है कि MSBuild सेटअप के साथ भी, बिल्ड और प्रोजेक्ट के साथ काम करना Visual Studio IDE में उतना ही सहज होगा जितना कि इसके बाहर।
MSBuild बनाम project.json
अब निम्न कमांड निष्पादित करके .NET कोर प्रीव्यू 2 टूलिंग के साथ एक नया कंसोल प्रोजेक्ट बनाते हैं।
dotnet new -t console
इस परियोजना के भीतर बनाई गई सभी फाइलों को देखने के लिए, चलाएँ dir आदेश।
आप देख सकते हैं कि दो फाइलें बनाई गई हैं, Program.cs तथा project.json फ़ाइल।
अब निम्न कमांड को निष्पादित करके .NET कोर 2 प्रीव्यू 1 टूलिंग के साथ एक कंसोल ऐप बनाते हैं।
dotnet new console
इस परियोजना के भीतर बनाई गई सभी फाइलों को देखने के लिए, चलाएँ dirआदेश। आप देख सकते हैं कि तीन फाइलें बनाई गई हैं,Program.cs, NuGet.config तथा MSBuild.csproj Project.json फ़ाइल के बजाय।
आइए अब तुलना करते हैं project.json तथा MSBuild.csproj फ़ाइलें पक्ष की ओर से।
बाईं ओर, हमारे पास json प्रारूप में फ़ाइल है जबकि दाईं ओर, फ़ाइल XML प्रारूप में है। आप देख सकते हैं कि project.json फ़ाइल में, निर्भरता अनुभाग के अंदर, हैnetcoreapp1.0, जबकि MSBuild.csproj फ़ाइल में, आप देखेंगे netcoreapp2.0।
इस अध्याय में, हम चर्चा करेंगे कि कमांड लाइन उपयोगिता का उपयोग करके अपने MSBuild (* .csproj) फ़ाइल को कैसे पुनर्स्थापित करें और बनाएं। .NET Core 2.0 पूर्वावलोकन 1 में कौन सी कमांड उपलब्ध हैं, यह देखने के लिए, हम निम्नलिखित कमांड चलाते हैं।
dotnet help
आपको सभी कमांड जैसे नया, रिस्टोर, बिल्ड आदि दिखाई देगा।
निम्नलिखित में डिफ़ॉल्ट कार्यान्वयन है Program.cs फ़ाइल।
using System;
namespace MSBuild {
class Program {
static void Main(string[] args) {
Console.WriteLine("Hello World!");
}
}
}
चलिए अब प्रगति को देखने के लिए निम्न कमांड निष्पादित करते हैं।
dotnet build
आपको बहुत सारी त्रुटियाँ दिखाई देंगी। इन त्रुटियों को सुधारने की आवश्यकता है।
अब हम निम्नलिखित कमांड चलाते हैं।
dotnet restore
आप देख सकते हैं कि सभी पैकेज बहाल हैं। कुछ नए फोल्डर और फाइलें भी जेनरेट की गई हैं।
निर्देशिका संरचना को देखने के लिए, हम निम्नलिखित कमांड चलाते हैं।
tree /f
निम्नलिखित निर्देशिका संरचना है -
आइए अब निम्नलिखित कमांड को फिर से चलाने वाले प्रोजेक्ट का पुनर्निर्माण करते हैं।
dotnet build
अब आप बिना किसी त्रुटि के सफलतापूर्वक निर्माण करेंगे और MSBuild.dll भी बनाया गया है।
आउटपुट देखने के लिए, हम निम्नलिखित कमांड चलाते हैं -
dotnet run
आप अपने कंसोल पर निम्न आउटपुट देख सकते हैं।
इस अध्याय में, हम कंसोल एप्लिकेशन को माइग्रेट करेंगे जिसमें समाहित है project.json फ़ाइल निर्माण प्रणाली के बजाय MSBuild (*.csproj)। तो, हमारे पास एक पुरानी परियोजना है जिसमें निम्नलिखित फाइलें हैं।
अब सवाल यह है कि हमें प्रवास की आवश्यकता क्यों है? यह प्रोजेक्ट .NET कोर 1.0 पूर्वावलोकन 2 टूलिंग का उपयोग करके बनाया गया है और अब हमने .NET कोर 2.0 पूर्वावलोकन 1 टूलिंग स्थापित किया है। अब जब आप .NET कोर 2.0 कमांड लाइन उपयोगिता का उपयोग करके इस एप्लिकेशन का निर्माण करते हैं, तो आपको निम्न त्रुटि दिखाई देगी।
इसकी वजह है project.jsonबिल्ड सिस्टम .NET .NET 2.0 में उपलब्ध नहीं है, इसलिए हमें माइग्रेशन की आवश्यकता है ताकि यह ठीक से काम कर सके। उपलब्ध कमांड देखने के लिए, हम निम्नलिखित कमांड चलाते हैं।
dotnet help
कमांड सेक्शन में, आप अलग-अलग कमांड देख सकते हैं और आप भी देख सकते हैं migrate एक MSBuild आधारित परियोजना के लिए एक प्रोजेक्ट .json आधारित परियोजना को माइग्रेट करेगा जो कमांड।
अब हम निम्नलिखित कमांड चलाते हैं।
dotnet migrate
आपको माइग्रेशन प्रक्रिया का सारांश दिखाई देगा और यहां आप यह भी देख सकते हैं कि कोई प्रोजेक्ट सफलतापूर्वक माइग्रेट किया गया है।
अब निम्न कमांड का उपयोग करके डायरेक्टरी स्ट्रक्चर को देखते हैं।
tree /f
अब आपको * .csproj फ़ाइल के साथ Program.cs फ़ाइल प्रोजेक्ट रूट डायरेक्टरी में दिखाई देगी और project.json को बैकअप फ़ोल्डर में ले जाया जाएगा।
हमें खुलने दो console.csprojफ़ाइल। अब आप निम्न आदेश को चलाकर MSBuild सिस्टम का उपयोग करके इस प्रोजेक्ट को पुनर्स्थापित और निर्माण कर सकते हैं।
dotnet restore
अब आप देख सकते हैं कि सभी पैकेज बहाल हैं।
अब आप निम्न कमांड के साथ अपना प्रोजेक्ट बना सकते हैं।
dotnet build
अब आप देख सकते हैं कि प्रोजेक्ट MSBuild का उपयोग करके सफलतापूर्वक बनाया गया है और कंसोल .ll भी जनरेट किया गया है ..\bin\Debug\netcoreapp1.0 फ़ोल्डर।
निम्न स्क्रीनशॉट निर्देशिका संरचना और फ़ाइलों को दिखाता है।