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