कोटलिन - त्वरित गाइड
कोटलिन जावा, जावास्क्रिप्ट, आदि की तरह एक नई ओपन सोर्स प्रोग्रामिंग भाषा है। यह एक उच्च स्तरीय दृढ़ता से वैधानिक रूप से टाइप की जाने वाली भाषा है जो एक ही स्थान पर कार्यात्मक और तकनीकी भाग को जोड़ती है। वर्तमान में, कोटलिन जावा और जावास्क्रिप्ट को लक्षित करता है। यह जेवीएम पर चलता है।
कोटलिन अन्य प्रोग्रामिंग भाषाओं जैसे कि जावा, स्काला, ग्रूवी, गोसू, आदि से प्रभावित है। कोटलिन का सिंटैक्स 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 - जावा की तरह, कोटलिन भी कैच ब्लॉक को अंजाम देने के बाद आखिरकार ब्लॉक को अंजाम देता है।