Kotlin - klasa i obiekt

W tym rozdziale poznamy podstawy programowania obiektowego (OOP) przy użyciu Kotlina. Dowiemy się o klasie i jej przedmiocie oraz o tym, jak się nim bawić. Z definicji OOP, klasa jest planem jednostki wykonawczej, a obiekt to jej stan, który obejmuje zarówno jej zachowanie, jak i stan. W Kotlinie deklaracja klasy składa się z nagłówka klasy i treści klasy otoczonej nawiasami klamrowymi, podobnie jak w Javie.

Class myClass { // class Header 

   // class Body
}

Podobnie jak Java, Kotlin pozwala również na tworzenie kilku obiektów klasy i możesz swobodnie dołączać jej członków i funkcje. Możemy kontrolować widoczność zmiennych składowych klasy za pomocą różnych słów kluczowych, których nauczymy się w rozdziale 10 - Kontrola widoczności. W poniższym przykładzie utworzymy jedną klasę i jej obiekt, za pośrednictwem których uzyskamy dostęp do różnych członków danych tej klasy.

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()
}

Powyższy fragment kodu da następujący wynik w przeglądarce, w której wywołujemy printMe () myClass przy użyciu jej własnego obiektu.

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

Klasa zagnieżdżona

Z definicji, gdy klasa została utworzona wewnątrz innej klasy, wówczas nazywana jest klasą zagnieżdżoną. W Kotlinie klasa zagnieżdżona jest domyślnie statyczna, dlatego można uzyskać do niej dostęp bez tworzenia żadnego obiektu tej klasy. W poniższym przykładzie zobaczymy, jak Kotlin interpretuje naszą zagnieżdżoną klasę.

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"
   }
}

Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce.

Welcome to The TutorialsPoint.com

Klasa wewnętrzna

Gdy klasa zagnieżdżona jest oznaczona jako „wewnętrzna”, będzie nazywana klasą wewnętrzną. Dostęp do klasy wewnętrznej może uzyskać element członkowski danych klasy zewnętrznej. W poniższym przykładzie będziemy uzyskiwać dostęp do elementu członkowskiego danych klasy zewnętrznej.

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
   }
}

Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce, w której wywołujemy klasę zagnieżdżoną przy użyciu domyślnego konstruktora dostarczonego przez kompilatory Kotlin w czasie kompilacji.

Welcome to the TutorialsPoint.com

Anonimowa klasa wewnętrzna

Anonimowa klasa wewnętrzna to całkiem niezła koncepcja, która bardzo ułatwia życie programisty. Zawsze, gdy wdrażamy interfejs, pojawia się koncepcja anonimowego wewnętrznego bloku. Koncepcja tworzenia obiektu interfejsu przy użyciu odwołania do obiektu środowiska wykonawczego jest znana jako klasa anonimowa. W poniższym przykładzie utworzymy interfejs i utworzymy obiekt tego interfejsu przy użyciu mechanizmu klasy Anonymous Inner.

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()
}

Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce.

I am an example of Anonymous Inner Class

Wpisz Aliasy

Aliasy typów są własnością kompilatora Kotlin. Zapewnia elastyczność tworzenia nowej nazwy istniejącego typu, nie tworzy nowego typu. Jeśli nazwa typu jest zbyt długa, możesz łatwo wprowadzić krótszą nazwę i użyć jej w przyszłości. Aliasy typów są bardzo przydatne w przypadku złożonych typów. W najnowszej wersji Kotlin odwołał wsparcie dla aliasów typów, jednak jeśli używasz starej wersji Kotlin, możesz go używać w następujący sposób -

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