कोटलिन - त्वरित गाइड

कोटलिन जावा, जावास्क्रिप्ट, आदि की तरह एक नई ओपन सोर्स प्रोग्रामिंग भाषा है। यह एक उच्च स्तरीय दृढ़ता से वैधानिक रूप से टाइप की जाने वाली भाषा है जो एक ही स्थान पर कार्यात्मक और तकनीकी भाग को जोड़ती है। वर्तमान में, कोटलिन जावा और जावास्क्रिप्ट को लक्षित करता है। यह जेवीएम पर चलता है।

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

फायदे और नुकसान

अपने आवेदन के विकास के लिए कोटलिन का उपयोग करने के कुछ फायदे निम्नलिखित हैं।

Easy Language- कोटलिन एक कार्यात्मक भाषा है और सीखने में बहुत आसान है। वाक्यविन्यास जावा के समान सुंदर है, इसलिए इसे याद रखना बहुत आसान है। कोटलिन अधिक अभिव्यंजक है, जो आपके कोड को अधिक पठनीय और समझने योग्य बनाता है।

Concise- कोटलिन JVM पर आधारित है और यह एक कार्यात्मक भाषा है। इस प्रकार, यह अन्य प्रोग्रामिंग भाषाओं में उपयोग किए जाने वाले बॉयलर प्लेट कोड को बहुत कम करता है।

Runtime and Performance - बेहतर प्रदर्शन और छोटा रनटाइम।

Interoperability - कम जटिल तरीके से इंटरऑपरेबल एप्लिकेशन के निर्माण के लिए कोटलिन पर्याप्त परिपक्व है।

Brand New- कोटलिन एक नई भाषा है जो डेवलपर्स को एक नई शुरुआत देती है। यह जावा का प्रतिस्थापन नहीं है, हालांकि इसे जेवीएम के ऊपर विकसित किया गया है। यह एंड्रॉइड डेवलपमेंट की पहली आधिकारिक भाषा के रूप में स्वीकार किया जाता है। कोटलिन को परिभाषित किया जा सकता है - कोटलिन = जावा + अतिरिक्त अद्यतन नई सुविधाएँ।

कोटलिन के कुछ नुकसान निम्नलिखित हैं।

Namespace declaration- कोटलिन डेवलपर्स को शीर्ष स्तर पर फ़ंक्शन घोषित करने की अनुमति देता है। हालांकि, जब भी आपके आवेदन के कई स्थानों पर एक ही फ़ंक्शन घोषित किया जाता है, तो यह समझना मुश्किल है कि किस फ़ंक्शन को कहा जा रहा है।

No Static Declaration - कोटलिन में जावा की तरह सामान्य स्थिर हैंडलिंग संशोधक नहीं है, जो पारंपरिक जावा डेवलपर के लिए कुछ समस्या पैदा कर सकता है।

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

Step 1 - जावा 8 स्थापना।

कोटलिन जेवीएम पर चलता है, इसलिए। अपने स्थानीय कोटलिन विकास के लिए जेडीके 8 का उपयोग करना वास्तव में आवश्यक है। कृपया JDK 8 या इसके बाद के संस्करण को डाउनलोड और इंस्टॉल करने के लिए oracle की आधिकारिक वेबसाइट देखें । आपको JAVA के लिए पर्यावरण चर सेट करना पड़ सकता है ताकि यह ठीक से काम कर सके। विंडोज ऑपरेटिंग सिस्टम में अपनी स्थापना को सत्यापित करने के लिए, कमांड प्रॉम्प्ट में "जावा-वर्जन" को हिट करें और आउटपुट के रूप में यह आपको आपके सिस्टम में स्थापित जावा संस्करण दिखाएगा।

Step 2 - आईडीई स्थापना।

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

आईडीई का नाम स्थापना लिंक
NetBeans https://netbeans.org/downloads/
ग्रहण https://www.eclipse.org/downloads/
Intellij https://www.jetbrains.com/idea/download/#section = windows

हमेशा हाल के सॉफ़्टवेयर संस्करण का उपयोग करने की सिफारिश की जाती है ताकि वह इससे अधिकतम सुविधा को खींच सके।

Step 3 - ग्रहण का विन्यास।

ग्रहण खोलें और "ग्रहण मार्केट प्लेस" पर जाएं। आपको निम्न स्क्रीन मिलेगी।

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

Step 4 - कोटलिन परियोजना।

एक बार जब ग्रहण सफलतापूर्वक शुरू हो जाता है और कोटलिन स्थापित हो जाता है, तो आप मक्खी पर कोटलिन प्रोजेक्ट बना पाएंगे। के लिए जाओFile → New → Others और सूची से "कोटलिन परियोजना" चुनें।

एक बार प्रोजेक्ट सेटअप हो जाने के बाद, आप "SRC" फ़ोल्डर के तहत एक कोटलिन फ़ाइल बना सकते हैं। "Src" फ़ोल्डर पर बायाँ-क्लिक करें और "नया" हिट करें। आपको कोटलिन फ़ाइल के लिए एक विकल्प मिलेगा, अन्यथा आपको "अन्य" से खोजना पड़ सकता है। एक बार नई फ़ाइल बन जाने के बाद, आपकी परियोजना निर्देशिका निम्नलिखित की तरह दिखाई देगी।

आपका विकास का वातावरण अब तैयार है। आगे बढ़ो और "Hello.kt" फ़ाइल में कोड का निम्नलिखित टुकड़ा जोड़ें।

fun main(args: Array<String>) {
   println("Hello, World!")
}

इसे कोटलिन एप्लिकेशन के रूप में चलाएं और कंसोल में आउटपुट को निम्न स्क्रीनशॉट में दिखाया गया है। बेहतर समझ और उपलब्धता के लिए, हम अपने कोडिंग ग्राउंड टूल का उपयोग करेंगे।

Hello, World!

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

कोटलिन कंपाइलर एक बाइट कोड बनाता है और वह बाइट कोड JVM पर चल सकता है, जो जावा द्वारा उत्पन्न बाइट कोड के बिल्कुल बराबर है .classफ़ाइल। जब भी दो बाइट कोडेड फाइल जेवीएम पर चलती है, तो वे एक दूसरे के साथ संवाद कर सकते हैं और यह है कि जावा के लिए कोटलिन में एक इंटरऑपरेबल सुविधा कैसे स्थापित की जाती है।

जब भी कोटलिन जावास्क्रिप्ट को लक्षित करता है, कोटलिन संकलक धर्मान्तरित होता है .ktES5.1 में फ़ाइल और जावास्क्रिप्ट के लिए एक संगत कोड उत्पन्न करता है। Kotlin संकलक LLVM के माध्यम से प्लेटफ़ॉर्म आधार संगत कोड बनाने में सक्षम है।

इस अध्याय में, हम कोटलिन प्रोग्रामिंग भाषा में उपलब्ध बुनियादी डेटा प्रकारों के बारे में जानेंगे।

नंबर

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

प्रकार आकार
दोहरा 64
फ्लोट 32
लंबा 64
पूर्णांक 32
कम 16
बाइट 8

निम्नलिखित उदाहरण में, हम देखेंगे कि कोटलिन विभिन्न डेटा प्रकारों के साथ कैसे काम करता है। कृपया हमारे कोडिंग ग्राउंड में कोड का निम्नलिखित सेट दर्ज करें।

fun main(args: Array<String>) {
   val a: Int = 10000
   val d: Double = 100.00
   val f: Float = 100.00f
   val l: Long = 1000000004
   val s: Short = 10
   val b: Byte = 1
   
   println("Your Int Value is "+a);
   println("Your Double  Value is "+d);
   println("Your Float Value is "+f);
   println("Your Long Value is "+l);
   println("Your Short Value is "+s);
   println("Your Byte Value is "+b);
}

जब आप कोडिंग ग्राउंड में उपरोक्त कोड को चलाते हैं, तो यह वेब कंसोल में निम्न आउटपुट उत्पन्न करेगा।

Your Int Value is 10000
Your Double  Value is 100.0
Your Float Value is 100.0
Your Long Value is 1000000004
Your Short Value is 10
Your Byte Value is 1

पात्र

कोटलिन चरित्र का प्रतिनिधित्व करता है char। चरित्र को एकल उद्धरण में घोषित किया जाना चाहिए‘c’। कृपया हमारे कोडिंग ग्राउंड में निम्नलिखित कोड दर्ज करें और देखें कि कैसे कोटलिन वर्ण चर की व्याख्या करता है। वर्ण चर को संख्या चर की तरह घोषित नहीं किया जा सकता है। Kotlin वैरिएबल को दो तरीकों से घोषित किया जा सकता है - एक का उपयोग करना“var” और दूसरा उपयोग कर रहा है “val”

fun main(args: Array<String>) {
   val letter: Char    // defining a variable 
   letter = 'A'        // Assigning a value to it 
   println("$letter")
}

कोड का उपरोक्त टुकड़ा ब्राउज़र आउटपुट विंडो में निम्न आउटपुट देगा।

A

बूलियन

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

fun main(args: Array<String>) {
   val letter: Boolean   // defining a variable 
   letter = true         // Assinging a value to it 
   println("Your character value is "+"$letter")
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

Your character value is true

स्ट्रिंग्स

तार चरित्र सरणियाँ हैं। जावा की तरह, वे प्रकृति में अपरिवर्तनीय हैं। कोटलिन में हमारे पास दो प्रकार के स्ट्रिंग उपलब्ध हैं - एक कहा जाता हैraw String और दूसरा कहा जाता है escaped String। निम्नलिखित उदाहरण में, हम इन तारों का उपयोग करेंगे।

fun main(args: Array<String>) {
   var rawString :String  = "I am Raw String!"
   val escapedString : String  = "I am escaped String!\n"
   
   println("Hello!"+escapedString)
   println("Hey!!"+rawString)   
}

बच गए स्ट्रिंग का उपरोक्त उदाहरण पहले प्रिंट स्टेटमेंट के बाद अतिरिक्त लाइन स्पेस प्रदान करने की अनुमति देता है। निम्नलिखित ब्राउज़र में आउटपुट होगा।

Hello!I am escaped String!

Hey!!I am Raw String!

सरणियों

Arrays सजातीय डेटा का एक संग्रह है। जावा की तरह, कोटलिन विभिन्न डेटा प्रकारों के सरणियों का समर्थन करता है। निम्नलिखित उदाहरण में, हम विभिन्न सरणियों का उपयोग करेंगे।

fun main(args: Array<String>) {
   val numbers: IntArray = intArrayOf(1, 2, 3, 4, 5)
   println("Hey!! I am array Example"+numbers[2])
}

उपरोक्त कोड का कोड निम्न आउटपुट देता है। सरणी का अनुक्रमण अन्य प्रोग्रामिंग भाषाओं के समान है। यहां, हम एक दूसरे इंडेक्स की खोज कर रहे हैं, जिसका मूल्य "3" है।

Hey!! I am array Example3

संग्रह

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

fun main(args: Array<String>) { 
   val numbers: MutableList<Int> = mutableListOf(1, 2, 3) //mutable List 
   val readOnlyView: List<Int> = numbers                  // immutable list 
   println("my mutable list--"+numbers)        // prints "[1, 2, 3]" 
   numbers.add(4) 
   println("my mutable list after addition --"+numbers)        // prints "[1, 2, 3, 4]" 
   println(readOnlyView)     
   readOnlyView.clear()    // ⇒ does not compile  
// gives error  
}

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

main.kt:9:18: error: unresolved reference: clear
   readOnlyView.clear()    // -> does not compile  
                 ^

संग्रह में, कोटलिन कुछ उपयोगी तरीके प्रदान करता है जैसे कि first(), last(), filter(), आदि ये सभी तरीके आत्म-वर्णनात्मक हैं और लागू करने में आसान हैं। इसके अलावा, कोटलिन संग्रह को लागू करते समय जावा जैसी संरचना का पालन करता है। आप अपनी पसंद के किसी भी संग्रह जैसे मानचित्र और सेट को लागू करने के लिए स्वतंत्र हैं।

निम्नलिखित उदाहरण में, हमने विभिन्न अंतर्निहित विधियों का उपयोग करके मानचित्र और सेट को लागू किया है।

fun main(args: Array<String>) {
   val items = listOf(1, 2, 3, 4)
   println("First Element of our list----"+items.first())
   println("Last Element of our list----"+items.last())
   println("Even Numbers of our List----"+items.
      filter { it % 2 = = 0 })   // returns [2, 4]
   
   val readWriteMap = hashMapOf("foo" to 1, "bar" to 2)
   println(readWriteMap["foo"])  // prints "1"
   
   val strings = hashSetOf("a", "b", "c", "c")
   println("My Set Values are"+strings)
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

First Element of our list----1
Last Element of our list----4
Even Numbers of our List----[2, 4]
1
My Set Values are[a, b, c]

सीमाओं

रंग कोटलिन की एक और अनूठी विशेषता है। हास्केल की तरह, यह एक ऑपरेटर प्रदान करता है जो आपको एक सीमा के माध्यम से पुनरावृति करने में मदद करता है। आंतरिक रूप से, इसका उपयोग करके कार्यान्वित किया जाता हैrangeTo() और इसका संचालक रूप है (..)

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

fun main(args: Array<String>) {
   val i:Int  = 2
   for (j in 1..4) 
   print(j) // prints "1234"
   
   if (i in 1..10) { // equivalent of 1 < = i && i < = 10
      println("we found your number --"+i)
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

1234we found your number --2

पिछले अध्याय में हमने कोटलिन प्रणाली में उपलब्ध विभिन्न प्रकार के डेटा प्रकारों के बारे में सीखा है। इस अध्याय में, हम कोटलिन में उपलब्ध विभिन्न प्रकार के नियंत्रण प्रवाह तंत्र पर चर्चा करेंगे।

यदि नहीं तो

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

fun main(args: Array<String>) {
   val a:Int = 5
   val b:Int = 2
   var max: Int
   
   if (a > b) {
      max = a
   } else {
      max = b
   }
   print("Maximum of a or b is " +max)
 
   // As expression 
   // val max = if (a > b) a else b
}

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

Maximum of a or b is 5

कब का उपयोग

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

fun main(args: Array<String>) {
   val x:Int = 5
   when (x) {
      1 -> print("x = = 1")
      2 -> print("x = = 2")
      
      else -> { // Note the block
         print("x is neither 1 nor 2")
      }
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

x is neither 1 nor 2

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

fun main(args: Array<String>) {
   val x:Int = 5
   when (x) {
      1,2 -> print(" Value of X either 1,2")
      
      else -> { // Note the block
         print("x is neither 1 nor 2")
      }
   }
}

ब्राउज़र में समान चलाएं, जो ब्राउज़र में निम्न आउटपुट देगा।

x is neither 1 nor 2

पाश के लिए

लूप एक ऐसा आविष्कार है जो किसी भी प्रकार की डेटा संरचना के माध्यम से पुनरावृति को लचीलापन प्रदान करता है। अन्य प्रोग्रामिंग भाषाओं की तरह, कोटलिन भी कई प्रकार की लूपिंग पद्धति प्रदान करता है, हालांकि, उनमें से“For”सबसे सफल है। फोर लूप का कार्यान्वयन और उपयोग वैचारिक रूप से लूप के लिए जावा के समान है। निम्नलिखित उदाहरण से पता चलता है कि हम वास्तविक जीवन के उदाहरणों में कैसे उपयोग कर सकते हैं।

fun main(args: Array<String>) {
   val items = listOf(1, 2, 3, 4)
   for (i in items) println("values of the array"+i)
}

उपरोक्त कोड में, हमने "आइटम" के रूप में नामित एक सूची घोषित की है और लूप के लिए हम उस परिभाषित सूची के माध्यम से पुनरावृत्ति कर रहे हैं और ब्राउज़र में इसके मूल्य को प्रिंट कर रहे हैं। निम्नलिखित आउटपुट है।

values of the array1
values of the array2
values of the array3
values of the array4

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

fun main(args: Array<String>) {
   val items = listOf(1, 22, 83, 4)
   
   for ((index, value) in items.withIndex()) {
      println("the element at $index is $value")
   }
}

एक बार जब हम अपने कोडिंग ग्राउंड में उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह ब्राउज़र में निम्न आउटपुट प्राप्त करेगा।

the element at 0 is 1
the element at 1 is 22
the element at 2 is 83
the element at 3 is 4

जबकि लूप और डू-जबकि लूप

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

fun main(args: Array<String>) {
   var x:Int = 0
   println("Example of While Loop--")
   
   while(x< = 10) {
      println(x)
      x++
   } 
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

Example of While Loop--
0
1
2
3
4
5
6
7
8
9
10

कोटलिन के पास डू-लूप नामक एक और लूप है, जहां लूप बॉडी को एक बार निष्पादित किया जाएगा, उसके बाद ही स्थिति की जांच की जाएगी। निम्न उदाहरण के उपयोग को दर्शाता हैDo-while loop

fun main(args: Array<String>) {
   var x:Int = 0
   do {
      x = x + 10
      println("I am inside Do block---"+x)
   } while(x <= 50)
}

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

I am inside Do block---10
I am inside Do block---20
I am inside Do block---30
I am inside Do block---40
I am inside Do block---50
I am inside Do block---60

रिटर्न, ब्रेक, कंटीन्यू का उपयोग

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

Return- रिटर्न एक कीवर्ड है जो कॉल किए गए फ़ंक्शन से कुछ फ़ंक्शन को कॉल करता है। निम्नलिखित उदाहरण में, हम अपने कोटलिन कोडिंग ग्राउंड का उपयोग करके इस परिदृश्य को लागू करेंगे।

fun main(args: Array<String>) {
   var x:Int = 10
   println("The value of X is--"+doubleMe(x))
}
fun doubleMe(x:Int):Int {
   return 2*x;
}

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

The value of X is--20

Continue & Break- जारी रखना और तोड़ना एक तार्किक समस्या का सबसे महत्वपूर्ण हिस्सा है। "ब्रेक" कीवर्ड नियंत्रक प्रवाह को समाप्त कर देता है यदि कुछ स्थिति विफल हो गई है और "जारी" इसके विपरीत करता है। यह सब ऑपरेशन तत्काल दृश्यता के साथ होता है। कोटलिन अन्य प्रोग्रामिंग भाषाओं की तुलना में अधिक स्मार्ट है, जिसमें डेवलपर दृश्यता के रूप में एक से अधिक लेबल लगा सकता है। कोड का निम्नलिखित टुकड़ा दिखाता है कि हम कोटलिन में इस लेबल को कैसे लागू कर रहे हैं।

fun main(args: Array<String>) {
   println("Example of Break and Continue")
   myLabel@ for(x in 1..10) { // appling the custom label
      if(x = = 5) {
         println("I am inside if block with value"+x+"\n-- hence it will close the operation")
         break@myLabel //specifing the label
      } else {
         println("I am inside else block with value"+x)
         continue@myLabel
      }
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

Example of Break and Continue
I am inside else block with value1
I am inside else block with value2
I am inside else block with value3
I am inside else block with value4
I am inside if block with value5
-- hence it will close the operation

जैसा कि आप देख सकते हैं, नियंत्रक लूप जारी रखता है, जब तक और जब तक कि मूल्य नहीं x है 5. एक बार का मान x 5 तक पहुंचता है, अगर यह ब्लॉक को ब्लॉक करना शुरू कर देता है और एक बार ब्रेक स्टेटमेंट तक पहुंच जाता है, तो संपूर्ण नियंत्रण प्रवाह प्रोग्राम निष्पादन को समाप्त कर देता है।

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

Class myClass { // class Header 

   // class Body
}

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

class myClass {
   // property (data member)
   private var name: String = "Tutorials.point"
   
   // member function
   fun printMe() {
      print("You are at the best Learning website Named-"+name)
   }
}
fun main(args: Array<String>) {
   val obj = myClass() // create obj object of myClass class
   obj.printMe()
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्नलिखित आउटपुट प्राप्त करेगा, जहां हम अपने ऑब्जेक्ट का उपयोग करके myClass के printMe () को कॉल कर रहे हैं।

You are at the best Learning website Named- Tutorials.point

नेस्टेड क्लास

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

fun main(args: Array<String>) {
   val demo = Outer.Nested().foo() // calling nested class method
   print(demo)
}
class Outer {
   class Nested {
      fun foo() = "Welcome to The TutorialsPoint.com"
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

Welcome to The TutorialsPoint.com

भीतरी वर्ग

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

fun main(args: Array<String>) {
   val demo = Outer().Nested().foo() // calling nested class method
   print(demo)
}
class Outer {
   private val welcomeMessage: String = "Welcome to the TutorialsPoint.com"
   inner class Nested {
      fun foo() = welcomeMessage
   }
}

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

Welcome to the TutorialsPoint.com

अनाम भीतरी वर्ग

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

fun main(args: Array<String>) {
   var programmer :Human = object:Human // creating an instance of the interface {
      override fun think() { // overriding the think method
         print("I am an example of Anonymous Inner Class ")
      }
   }
   programmer.think()
}
interface Human {
   fun think()
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

I am an example of Anonymous Inner Class

उपनाम लिखें

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

typealias NodeSet = Set<Network.Node>
typealias FileTable<K> = MutableMap<K, MutableList<File>>

इस अध्याय में, हम कोटलिन में निर्माणकर्ताओं के बारे में जानेंगे। कोटलिन के दो प्रकार के निर्माता हैं - एक हैprimary constructor और दूसरा है secondary constructor। एक कोटलिन वर्ग में एक प्राथमिक कंस्ट्रक्टर, और एक या अधिक माध्यमिक कंस्ट्रक्टर हो सकते हैं। जावा कंस्ट्रक्टर सदस्य चर को इनिशियलाइज़ करता है, हालाँकि, कोटलिन में प्राथमिक कंस्ट्रक्टर क्लास को इनिशियलाइज़ करता है, जबकि सेकेंडरी कंस्ट्रक्टर उसी को इनिशियलाइज़ करते समय कुछ एक्स्ट्रा लॉजिक को शामिल करने में मदद करता है। प्राथमिक निर्माता को कक्षा हेडर स्तर पर घोषित किया जा सकता है जैसा कि निम्नलिखित उदाहरण में दिखाया गया है।

class Person(val firstName: String, var age: Int) {
   // class body
}

उपरोक्त उदाहरण में, हमने कोष्ठक के अंदर प्राथमिक निर्माणकर्ता की घोषणा की है। दो क्षेत्रों के बीच, पहला नाम केवल पढ़ने के लिए है क्योंकि इसे "वैल" के रूप में घोषित किया गया है, जबकि क्षेत्र की आयु संपादित की जा सकती है। निम्नलिखित उदाहरण में, हम प्राथमिक कंस्ट्रक्टर का उपयोग करेंगे।

fun main(args: Array<String>) {
   val person1 = Person("TutorialsPoint.com", 15)
   println("First Name = ${person1.firstName}") println("Age = ${person1.age}")
}
class Person(val firstName: String, var age: Int) {
}

उपरोक्त कोड कोड स्वचालित रूप से दो वेरिएबल्स को इनिशियलाइज़ करेगा और ब्राउज़र में निम्न आउटपुट प्रदान करेगा।

First Name = TutorialsPoint.com
Age = 15

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

fun main(args: Array<String>) {
   val HUman = HUman("TutorialsPoint.com", 25)
   print("${HUman.message}"+"${HUman.firstName}"+
      "Welcome to the example of Secondary  constructor, Your Age is-${HUman.age}")
}
class HUman(val firstName: String, var age: Int) {
   val message:String  = "Hey!!!"
	constructor(name : String , age :Int ,message :String):this(name,age) {
   }
}

Note - किसी भी संख्या में द्वितीयक निर्माणकर्ता बनाए जा सकते हैं, हालाँकि, उन सभी निर्माणकर्ताओं को प्रत्यक्ष या अप्रत्यक्ष रूप से प्राथमिक निर्माणकर्ता को कॉल करना चाहिए।

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

Hey!!! TutorialsPoint.comWelcome to the example of Secondary  constructor, Your Age is- 25

इस अध्याय में, हम विरासत के बारे में जानेंगे। परिभाषा के अनुसार, हम सभी जानते हैं कि वंशानुक्रम का अर्थ है कि माँ वर्ग के कुछ गुणों को बाल वर्ग में लाना। कोटलिन में, बेस क्लास को "कोई भी" नाम दिया गया है, जो कोटलिन में घोषित 'किसी भी' डिफ़ॉल्ट वर्ग का सुपर क्लास है। अन्य सभी OOPS की तरह, कोटलिन भी इस कार्यक्षमता को प्रदान करता है जिसे एक कीवर्ड के रूप में जाना जाता है“:”

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

import java.util.Arrays

open class ABC {
   fun think () {
      print("Hey!! i am thiking ")
   }
}
class BCD: ABC(){ // inheritence happend using default constructor 
}

fun main(args: Array<String>) {
   var  a = BCD()
   a.think()
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

Hey!! i am thiking

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

import java.util.Arrays

open class ABC {
   open fun think () {
      print("Hey!! i am thinking ")
   }
}
class BCD: ABC() { // inheritance happens using default constructor 
   override fun think() {
      print("I Am from Child")
   }
}
fun main(args: Array<String>) {
   var  a = BCD()
   a.think()
}

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

I Am from Child

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

interface ExampleInterface {
   var myVar: String     // abstract property
   fun absMethod()       // abstract method
   fun sayHello() = "Hello there" // method with default implementation
}

उपर्युक्त उदाहरण में, हमने एक उदाहरण बनाया है जिसका नाम "ExampleInterface" है और इसके अंदर हमारे पास कुछ अमूर्त गुण और तरीके हैं। "SayHello ()" नाम के फ़ंक्शन को देखें, जो एक कार्यान्वित विधि है।

निम्नलिखित उदाहरण में, हम एक वर्ग में उपरोक्त इंटरफ़ेस को लागू करेंगे।

interface ExampleInterface  {
   var myVar: Int            // abstract property
   fun absMethod():String    // abstract method
   
   fun hello() {
      println("Hello there, Welcome to TutorialsPoint.Com!")
   }
}
class InterfaceImp : ExampleInterface {
   override var myVar: Int = 25
   override fun absMethod() = "Happy Learning "
}
fun main(args: Array<String>) {
   val obj = InterfaceImp()
   println("My Variable Value is = ${obj.myVar}")
   print("Calling hello(): ")
   obj.hello()
   
   print("Message from the Website-- ")
   println(obj.absMethod())
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

My Variable Value is = 25
Calling hello(): Hello there, Welcome to TutorialsPoint.Com!
Message from the Website-- Happy Learning

जैसा कि पहले उल्लेख किया गया है, कोटलिन कई विरासतों का समर्थन नहीं करता है, हालांकि, एक ही समय में दो से अधिक इंटरफेस को लागू करके एक ही चीज हासिल की जा सकती है।

निम्नलिखित उदाहरण में, हम दो इंटरफेस बनाएंगे और बाद में हम दोनों इंटरफेस को एक कक्षा में लागू करेंगे।

interface A {
   fun printMe() {
      println(" method of interface A")
   }
}
interface B  {
   fun printMeToo() {
      println("I am another Method from interface B")
   }
}

// implements two interfaces A and B
class multipleInterfaceExample: A, B

fun main(args: Array<String>) {
   val obj = multipleInterfaceExample()
   obj.printMe()
   obj.printMeToo()
}

उपर्युक्त उदाहरण में, हमने A, B और "multipleInterfaceExample" नामक दो नमूना इंटरफेस बनाए हैं, हमने पहले घोषित किए गए दो इंटरफेस लागू किए हैं। कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

method of interface A
I am another Method from interface B

इस अध्याय में, हम कोटलिन भाषा में उपलब्ध विभिन्न संशोधक के बारे में जानेंगे। Access modifierअनुप्रयोग में उपयोग किए जाने वाले चर, विधियों और वर्ग के उपयोग को प्रतिबंधित करने के लिए उपयोग किया जाता है। अन्य ओओपी प्रोग्रामिंग भाषा की तरह, यह संशोधक कई स्थानों पर लागू होता है जैसे कि क्लास हेडर या विधि घोषणा। कोटलिन में चार एक्सेस मॉडिफायर उपलब्ध हैं।

निजी

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

private class privateExample {
   private val i = 1
   private val doSomething() {
   }
}

उपरोक्त उदाहरण में, वर्ग “privateExample” और चर I दोनों को केवल उसी कोटलिन फ़ाइल में पहुँचा जा सकता है, जहाँ इसका उल्लेख किया गया है क्योंकि वे सभी घोषणा खंड में निजी घोषित किए गए हैं।

संरक्षित

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

class A() {
   protected val i = 1
}
class B : A() {
   fun getValue() : Int {
      return i
   }
}

उपरोक्त उदाहरण में, चर “i” इसे संरक्षित घोषित किया गया है, इसलिए, यह केवल इसके उपवर्ग को दिखाई देता है।

अंदर का

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

class internalExample {
   internal val i = 1
   internal fun doSomething() {
   }
}

उपरोक्त उदाहरण में, "doSomething" नाम की विधि और चर को आंतरिक के रूप में उल्लिखित किया गया है, इसलिए, ये दोनों फ़ील्ड केवल उस पैकेज के अंदर पहुंच योग्य हो सकते हैं जिसके तहत यह घोषित किया गया है।

जनता

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

class publicExample {
   val i = 1
   fun doSomething() {
   }
}

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

इस अध्याय में, हम "एक्सटेंशन" नाम के कोटलिन की एक और नई विशेषता के बारे में जानेंगे। विस्तार का उपयोग करते हुए, हम उन्हें विरासत में या संशोधित किए बिना भी कुछ विधि कार्यक्षमता को जोड़ने या निकालने में सक्षम होंगे। एक्सटेंशन का समाधान सांख्यिकीय रूप से किया जाता है। यह वास्तव में मौजूदा वर्ग को संशोधित नहीं करता है, लेकिन यह एक कॉल करने योग्य फ़ंक्शन बनाता है जिसे डॉट ऑपरेशन के साथ बुलाया जा सकता है।

कार्य विस्तार

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

class Alien {
   var skills : String = "null"
	
   fun printMySkills() {
      print(skills)
   }		
}
fun main(args: Array<String>) {
   var  a1 = Alien()
   a1.skills = "JAVA"
   //a1.printMySkills()
	
   var  a2 = Alien()
   a2.skills = "SQL"
   //a2.printMySkills()
	
   var  a3 = Alien()
   a3.skills = a1.addMySkills(a2)
   a3.printMySkills()
}
fun Alien.addMySkills(a:Alien):String{
   var a4 = Alien()
   a4.skills = this.skills + " " +a.skills
   return a4.skills
}

उपरोक्त उदाहरण में, हमारे पास "addMySkills ()" के रूप में नामित "विदेशी" वर्ग के अंदर कोई विधि नहीं है, हालांकि, हम अभी भी कक्षा के बाहर कहीं और उसी पद्धति को लागू कर रहे हैं, यह विस्तार का जादू है।

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा।

JAVA SQL

वस्तु विस्तार

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

fun main(args: Array<String>) {
   println("Heyyy!!!"+A.show())
}
class A {
   companion object {
      fun show():String {
         return("You are learning Kotlin from TutorialsPoint.com")
      }
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

Heyyy!!! You are learning Kotlin from TutorialsPoint.com

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

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

सभी डेटा वर्गों में एक प्राथमिक कंस्ट्रक्टर होना चाहिए और सभी प्राथमिक कंस्ट्रक्टर के पास कम से कम एक पैरामीटर होना चाहिए। जब भी किसी वर्ग को डेटा के रूप में चिह्नित किया जाता है, हम उस डेटा वर्ग के कुछ इनबिल्ट फ़ंक्शन का उपयोग कर सकते हैं जैसे कि "toString ()", "हैशकोड ()", आदि। किसी भी डेटा वर्ग में अमूर्त और खुला या आंतरिक जैसा कोई संशोधक नहीं हो सकता है। डेटा क्लास को अन्य वर्गों के लिए भी बढ़ाया जा सकता है। निम्नलिखित उदाहरण में, हम एक डेटा क्लास बनाएंगे।

fun main(args: Array<String>) {
   val book: Book = Book("Kotlin", "TutorialPoint.com", 5)
   println("Name of the Book is--"+book.name) // "Kotlin"
   println("Puclisher Name--"+book.publisher) // "TutorialPoint.com"
   println("Review of the book is--"+book.reviewScore) // 5
   book.reviewScore = 7
   println("Printing all the info all together--"+book.toString()) 
   //using inbuilt function of the data class 
   
   println("Example of the hashCode function--"+book.hashCode())
}

data class Book(val name: String, val publisher: String, var reviewScore: Int)

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

Name of the Book is--"Kotlin"
Puclisher Name--"TutorialPoint.com"
Review of the book is--5
Printing all the info all together--(name-Kotlin, publisher-TutorialPoint.com, reviewScore-7)
Example of the hashCode function---1753517245

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

sealed class MyExample {
   class OP1 : MyExample() // MyExmaple class can be of two types only
   class OP2 : MyExample()
}
fun main(args: Array<String>) {
   val obj: MyExample = MyExample.OP2() 
   
   val output = when (obj) { // defining the object of the class depending on the inuputs 
      is MyExample.OP1 -> "Option One has been chosen"
      is MyExample.OP2 -> "option Two has been chosen"
   }
   
   println(output)
}

उपरोक्त उदाहरण में, हमारे पास "MyExample" नाम से एक सील वर्ग है, जो केवल दो प्रकार के हो सकते हैं - एक "OP1" है और दूसरा "OP2" है। मुख्य वर्ग में, हम अपनी कक्षा में एक ऑब्जेक्ट बना रहे हैं और रनटाइम पर इसके प्रकार को निर्दिष्ट कर रहे हैं। अब, चूंकि यह "MyExample" वर्ग सील है, हम अंतिम आउटपुट को लागू करने के लिए रनटाइम पर "जब" क्लॉज लागू कर सकते हैं।

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

option Two has been chosen

जावा की तरह, कोटलिन जेनेरिक के रूप में चर टाइपिंग के उच्च क्रम प्रदान करता है। इस अध्याय में, हम सीखेंगे कि कैसे कोटलिन जेनरिक को लागू करता है और एक डेवलपर के रूप में हम जेनरिक लाइब्रेरी के अंदर प्रदान की गई उन कार्यक्षमता का उपयोग कर सकते हैं। कार्यान्वयन के अनुसार, जेनेरिक जावा के समान है लेकिन कोटलिन डेवलपर ने दो नए कीवर्ड पेश किए हैं“out” तथा “in” डेवलपर के लिए कोटलिन कोड को अधिक पठनीय और आसान बनाना।

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

fun main(args: Array<String>) {
   val integer: Int = 1
   val number: Number = integer
   print(number)
}

उपरोक्त कोड में, हमने एक "पूर्णांक" घोषित किया है और बाद में हमने उस चर को एक संख्या चर में सौंपा है। यह संभव है क्योंकि "Int" संख्या वर्ग का एक उपवर्ग है, इसलिए टाइप रूपांतरण स्वचालित रूप से रनटाइम पर होता है और आउटपुट "" "" के रूप में उत्पन्न होता है।

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

fun main(args: Array<String>) {
   var objet = genericsExample<String>("JAVA")
   var objet1 = genericsExample<Int>(10)
}
class genericsExample<T>(input:T) {
   init {
      println("I am getting called with the value "+input)
   }
}

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

I am getting called with the value JAVA
I am getting called with the value 10

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

fun main(args: Array<String>) {
   var objet1 = genericsExample<Int>(10)
   var object2 = genericsExample<Double>(10.00)
   println(objet1)
   println(object2)
}
class genericsExample<out T>(input:T) {
   init {
      println("I am getting called with the value "+input)
   }
}

उपरोक्त कोड ब्राउज़र में निम्न आउटपुट देगा।

I am getting called with the value 10
I am getting called with the value 10.0
genericsExample@28d93b30
genericsExample@1b6d3586

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

interface Base {
   fun printMe() //abstract method
}
class BaseImpl(val x: Int) : Base {
   override fun printMe() { println(x) }   //implementation of the method
}
class Derived(b: Base) : Base by b  // delegating the public method on the object b

fun main(args: Array<String>) {
   val b = BaseImpl(10)
   Derived(b).printMe() // prints 10 :: accessing the printMe() method 
}

उदाहरण में, हमारे पास "प्रिंटमे" () नाम के सार तत्व के साथ एक इंटरफ़ेस "बेस" है। BaseImpl वर्ग में, हम इस "प्रिंटमे ()" को लागू कर रहे हैं और बाद में किसी अन्य वर्ग से हम "कीवर्ड" का उपयोग करके इस कार्यान्वयन का उपयोग कर रहे हैं।

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

10

संपत्ति का प्रत्यायोजन

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

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

आलसी () का उपयोग करना

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

val myVar: String by lazy {
   "Hello"
}
fun main(args: Array<String>) {
   println(myVar +" My dear friend")
}

उपरोक्त कोड में, हम आलसी फ़ंक्शन के लिए एक चर "myVar" पास कर रहे हैं, जो बदले में अपनी वस्तु को मूल्य प्रदान करता है और मुख्य फ़ंक्शन को वही लौटाता है। ब्राउज़र में आउटपुट निम्न है।

Hello My dear friend

Delegetion.Observable ()

ऑब्जर्वेबल () ऑब्जेक्ट को इनिशियलाइज़ करने के लिए दो तर्क लेता है और इसे तथाकथित फंक्शन में लौटाता है। निम्नलिखित उदाहरण में, हम देखेंगे कि प्रतिनिधिमंडल को लागू करने के लिए ऑब्जर्वेबल () पद्धति का उपयोग कैसे किया जाए।

import kotlin.properties.Delegates
class User {
   var name: String by Delegates.observable("Welcome to Tutorialspoint.com") {
      prop, old, new ->
      println("$old -> $new")
   }
}
fun main(args: Array<String>) {
   val user = User()
   user.name = "first"
   user.name = "second"
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

first -> second

सामान्य तौर पर, "द्वारा" कीवर्ड के बाद सिंटैक्स अभिव्यक्ति है। get() तथा set() चर के तरीके p को सौंप दिया जाएगा getValue() तथा setValue() डेलिगेट वर्ग में परिभाषित तरीके।

class Example {
   var p: String by Delegate()
}

उपरोक्त कोड के लिए, निम्नलिखित प्रतिनिधि श्रेणी है जिसे हमें चर में मान निर्दिष्ट करने के लिए उत्पन्न करने की आवश्यकता है p

class Delegate {
   operator fun getValue(thisRef: Any?, property: KProperty<*>): String {
      return "$thisRef, thank you for delegating '${property.name}' to me!"
   }
   operator fun setValue(thisRef: Any?, property: KProperty<*>, value: String) {
      println("$value has been assigned to '${property.name} in $thisRef.'")
   }
}

पढ़ते समय, getValue () विधि को बुलाया जाएगा और चर setValue () विधि को सेट करते समय कहा जाएगा।

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

निम्नलिखित उदाहरण में, हम MyFunction नामक एक फ़ंक्शन को परिभाषित कर रहे हैं और मुख्य फ़ंक्शन से हम इस फ़ंक्शन को कॉल कर रहे हैं और कुछ तर्क पारित कर रहे हैं।

fun main(args: Array<String>) {
   println(MyFunction("tutorialsPoint.com"))
}
fun MyFunction(x: String): String {
   var c:String  = "Hey!! Welcome To ---"
   return (c+x)
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

Hey!! Welcome To ---tutorialsPoint.com

फ़ंक्शन को निम्नानुसार घोषित किया जाना चाहिए -

fun <nameOfFunction>(<argument>:<argumentType>):<ReturnType>

कोटलिन में उपलब्ध विभिन्न प्रकार के फ़ंक्शन निम्नलिखित हैं।

लंबोदर क्रिया

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

निम्नलिखित उदाहरण पर एक नज़र डालें।

fun main(args: Array<String>) {
   val mylambda :(String)->Unit  = {s:String->print(s)}
   val v:String = "TutorialsPoint.com"
   mylambda(v)
}

उपरोक्त कोड में, हमने अपना स्वयं का मेमना बनाया है जिसे “mylambda” के रूप में जाना जाता है और हमने इस भेड़ के बच्चे को एक चर दिया है, जो स्ट्रिंग का प्रकार है और इसमें एक मान है “TutorialsPoint.com”।

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

TutorialsPoint.com

इनलाइन समारोह

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

निम्नलिखित उदाहरण पर एक नज़र डालें।

fun main(args: Array<String>) {
   val mylambda:(String)->Unit  = {s:String->print(s)}
   val v:String = "TutorialsPoint.com"
   myFun(v,mylambda) //passing lambda as a parameter of another function 
}
fun myFun(a :String, action: (String)->Unit) { //passing lambda 
   print("Heyyy!!!")
   action(a)// call to lambda function
}

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

Heyyy!!!TutorialsPoint.com

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

निम्नलिखित विनाशकारी घोषणा का मूल वाक्यविन्यास है।

val (name, age) = person

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

println(name)
println(age)

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

fun main(args: Array<String>) {
   val s = Student("TutorialsPoint.com","Kotlin")
   val (name,subject) = s
   println("You are learning "+subject+" from "+name)
}
data class Student( val a :String,val b: String ){
   var name:String = a
   var subject:String = b
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

You are learning Kotlin from TutorialsPoint.com

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

fun main(args: Array<String>) {
   try {
      val myVar:Int = 12;
      val v:String = "Tutorialspoint.com";
      v.toInt();
   } catch(e:Exception) {
      e.printStackTrace();
   } finally {
      println("Exception Handeling in Kotlin");
   }
}

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

val myVar:Int = 12;
Exception Handeling in Kotlin

Note - जावा की तरह, कोटलिन भी कैच ब्लॉक को अंजाम देने के बाद आखिरकार ब्लॉक को अंजाम देता है।