Kotlin - Szybki przewodnik

Kotlin to nowy język programowania typu open source, taki jak Java, JavaScript itp. Jest to język wysokiego poziomu z silnymi typami statycznymi, który łączy funkcjonalną i techniczną część w jednym miejscu. Obecnie Kotlin jest ukierunkowany na Javę i JavaScript. Działa na JVM.

Kotlin jest pod wpływem innych języków programowania, takich jak Java, Scala, Groovy, Gosu itp. Składnia Kotlin może nie być dokładnie podobna do JAVA, jednak wewnętrznie Kotlin jest zależny od istniejącej biblioteki klas Java, aby zapewnić programistom wspaniałe wyniki . Kotlin zapewnia współdziałanie, bezpieczeństwo kodu i przejrzystość programistom na całym świecie.

Zalety i wady

Oto kilka zalet korzystania z Kotlin do tworzenia aplikacji.

Easy Language- Kotlin to język funkcjonalny i bardzo łatwy do nauczenia. Składnia jest bardzo podobna do Javy, dlatego jest bardzo łatwa do zapamiętania. Kotlin jest bardziej wyrazisty, dzięki czemu Twój kod jest bardziej czytelny i zrozumiały.

Concise- Kotlin jest oparty na JVM i jest językiem funkcjonalnym. W ten sposób zmniejsza ilość kodu źródłowego używanego w innych językach programowania.

Runtime and Performance - Lepsza wydajność i mały czas pracy.

Interoperability - Kotlin jest na tyle dojrzały, aby zbudować interoperacyjną aplikację w mniej złożony sposób.

Brand New- Kotlin to zupełnie nowy język, który daje programistom nowy start. Nie zastępuje Java, chociaż jest rozwijany na JVM. Jest akceptowany jako pierwszy oficjalny język rozwoju Androida. Kotlin można zdefiniować jako - Kotlin = JAVA + dodatkowe zaktualizowane nowe funkcje.

Oto niektóre wady Kotlina.

Namespace declaration- Kotlin umożliwia programistom deklarowanie funkcji na najwyższym poziomie. Jednak za każdym razem, gdy ta sama funkcja jest zadeklarowana w wielu miejscach aplikacji, trudno jest zrozumieć, która funkcja jest wywoływana.

No Static Declaration - Kotlin nie ma zwykłego modyfikatora obsługi statycznej, takiego jak Java, co może stanowić problem dla konwencjonalnego programisty Java.

Jeśli jednak nadal chcesz używać Kotlin w trybie offline w swoim systemie lokalnym, musisz wykonać następujące kroki, aby skonfigurować lokalny obszar roboczy.

Step 1 - Instalacja Java 8.

Kotlin działa więc na JVM. naprawdę konieczne jest użycie JDK 8 do lokalnego rozwoju Kotlin. Zapoznaj się z oficjalną witryną Oracle, aby pobrać i zainstalować JDK 8 lub nowszą wersję. Może być konieczne ustawienie zmiennej środowiskowej dla JAVA, aby mogła działać poprawnie. Aby zweryfikować instalację w systemie operacyjnym Windows, naciśnij „java –version” w wierszu poleceń, a jako wynik wyświetli się wersja Java zainstalowana w systemie.

Step 2 - Instalacja IDE.

W Internecie dostępnych jest wiele IDE. Możesz użyć dowolnego swojego wyboru. W poniższej tabeli można znaleźć łącze pobierania różnych środowisk IDE.

Nazwa IDE Link do instalacji
NetBeans https://netbeans.org/downloads/
Zaćmienie https://www.eclipse.org/downloads/
Intellij https://www.jetbrains.com/idea/download/#section = windows

Zawsze zaleca się używanie najnowszej wersji oprogramowania, aby wyciągnąć z niego maksimum ułatwień.

Step 3 - Konfiguracja Eclipse.

Otwórz Eclipse i przejdź do „Eclipse Market Place”. Znajdziesz następujący ekran.

Wyszukaj Kotlin w polu wyszukiwania i zainstaluj to samo w swoim lokalnym systemie. Może to zająć trochę czasu w zależności od szybkości Internetu. Po pomyślnym zainstalowaniu może być konieczne ponowne uruchomienie Eclipse.

Step 4 - Projekt Kotlin.

Po pomyślnym ponownym uruchomieniu Eclipse i zainstalowaniu Kotlin, będziesz mógł stworzyć projekt Kotlin w locie. Iść doFile → New → Others i wybierz z listy „Projekt Kotlin”.

Po zakończeniu konfiguracji projektu możesz utworzyć plik Kotlin w folderze „SRC”. Kliknij lewym przyciskiem myszy folder „Src” i naciśnij „nowy”. Otrzymasz opcję pliku Kotlin, w przeciwnym razie będziesz musiał szukać od „innych”. Po utworzeniu nowego pliku katalog projektu będzie wyglądał następująco.

Twoje środowisko programistyczne jest już gotowe. Śmiało i dodaj następujący fragment kodu w pliku „Hello.kt”.

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

Uruchom go jako aplikację Kotlin i zobacz dane wyjściowe w konsoli, jak pokazano na poniższym zrzucie ekranu. Aby lepiej zrozumieć i zwiększyć dostępność, będziemy używać naszego narzędzia do kodowania.

Hello, World!

Kotlin jest językiem programowania i ma własną architekturę do przydzielania pamięci i tworzenia wysokiej jakości danych wyjściowych dla użytkownika końcowego. Poniżej przedstawiono różne scenariusze, w których kompilator Kotlin będzie działał inaczej, gdy jest przeznaczony dla innych języków, takich jak Java i JavaScript.

Kompilator Kotlin tworzy kod bajtowy i ten kod bajtowy może działać na JVM, co jest dokładnie równe kodowi bajtowemu wygenerowanemu przez Javę .classplik. Za każdym razem, gdy w JVM uruchamiany jest dwubajtowy plik z kodem, mogą się one ze sobą komunikować iw ten sposób w Kotlin dla Javy ustanawia się funkcję interoperacyjną.

Za każdym razem, gdy Kotlin jest ukierunkowany na JavaScript, kompilator Kotlin konwertuje plik .ktplik do ES5.1 i generuje kompatybilny kod dla JavaScript. Kompilator Kotlin jest w stanie tworzyć kody kompatybilne z platformą za pośrednictwem LLVM.

W tym rozdziale poznamy podstawowe typy danych dostępne w języku programowania Kotlin.

Liczby

Reprezentacja liczb w Kotlin jest dość podobna do Java, jednak Kotlin nie pozwala na wewnętrzną konwersję różnych typów danych. Poniższa tabela zawiera listę różnych długości zmiennych dla różnych numerów.

Rodzaj Rozmiar
Podwójnie 64
Pływak 32
Długo 64
Int 32
Krótki 16
Bajt 8

W poniższym przykładzie zobaczymy, jak Kotlin działa z różnymi typami danych. Proszę wprowadzić następujący zestaw kodów w naszym obszarze kodowania.

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

Po uruchomieniu powyższego fragmentu kodu w środowisku kodowania wygeneruje on następujące dane wyjściowe w konsoli internetowej.

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

Postacie

Kotlin reprezentuje postać używając char. Znak należy zadeklarować w pojedynczym cudzysłowie, np.‘c’. Wprowadź poniższy kod w naszym obszarze kodowania i zobacz, jak Kotlin interpretuje zmienną znakową. Zmienna znakowa nie może być deklarowana jak zmienna liczbowa. Zmienną Kotlin można zadeklarować na dwa sposoby - jeden za pomocą“var” i inne użycie “val”.

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

Powyższy fragment kodu przyniesie następujące wyniki w oknie danych wyjściowych przeglądarki.

A

Boolean

Boolean jest bardzo prosty, podobnie jak inne języki programowania. Mamy tylko dwie wartości logiczne - prawda lub fałsz. W poniższym przykładzie zobaczymy, jak Kotlin interpretuje Boolean.

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

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

Your character value is true

Smyczki

Ciągi znaków to tablice znaków. Podobnie jak Java, mają one niezmienny charakter. W Kotlinie dostępne są dwa rodzaje sznurków - jeden to tzwraw String i inny jest nazywany escaped String. W poniższym przykładzie wykorzystamy te ciągi.

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

Powyższy przykład Escaped String pozwala na zapewnienie dodatkowego odstępu między wierszami po pierwszej instrukcji print. Następujące będzie wyjście w przeglądarce.

Hello!I am escaped String!

Hey!!I am Raw String!

Tablice

Tablice to zbiór jednorodnych danych. Podobnie jak Java, Kotlin obsługuje tablice różnych typów danych. W poniższym przykładzie użyjemy różnych tablic.

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

Powyższy fragment kodu daje następujące dane wyjściowe. Indeksowanie tablicy jest podobne do innych języków programowania. Tutaj szukamy drugiego indeksu, którego wartość to „3”.

Hey!! I am array Example3

Kolekcje

Zbieranie jest bardzo ważną częścią struktury danych, co ułatwia inżynierom tworzenie oprogramowania. Kotlin ma dwa rodzaje kolekcji - jeden toimmutable collection (co oznacza listy, mapy i zestawy, których nie można edytować), a inny jest mutable collection(ten typ kolekcji jest edytowalny). Bardzo ważne jest, aby pamiętać o typie kolekcji używanej w Twojej aplikacji, ponieważ system Kotlin nie reprezentuje w nich żadnej konkretnej różnicy.

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  
}

Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce. Daje błąd, gdy próbujemy wyczyścić zmienną listę kolekcji.

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

W kolekcji Kotlin zapewnia kilka przydatnych metod, takich jak first(), last(), filter()itd. Wszystkie te metody mają charakter samoopisowy i są łatwe do wdrożenia. Ponadto Kotlin stosuje tę samą strukturę, jak Java, podczas implementacji kolekcji. Możesz dowolnie zaimplementować dowolną kolekcję, taką jak Mapa i Zestaw.

W poniższym przykładzie zaimplementowaliśmy Map i Set przy użyciu różnych wbudowanych metod.

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

Powyższy fragment kodu daje w przeglądarce następujące dane wyjściowe.

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]

Zakresy

Zakresy to kolejna wyjątkowa cecha Kotlina. Podobnie jak Haskell, zapewnia operator, który pomaga iterować w zakresie. Wewnętrznie jest to realizowane za pomocąrangeTo() a jego formą operatora jest (..).

W poniższym przykładzie zobaczymy, jak Kotlin interpretuje ten operator zakresu.

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

Powyższy fragment kodu daje w przeglądarce następujące dane wyjściowe.

1234we found your number --2

W poprzednim rozdziale poznaliśmy różne typy typów danych dostępnych w systemie Kotlin. W tym rozdziale omówimy różne typy mechanizmów kontroli przepływu dostępnych w Kotlinie.

Jeśli inaczej

Kotlin jest językiem funkcjonalnym, a więc jak każdy język funkcjonalny w Kotlinie “if”jest wyrażeniem, nie jest słowem kluczowym. Ekspresja“if”zwróci wartość w razie potrzeby. Podobnie jak inne języki programowania,“if-else”blok jest używany jako początkowy operator sprawdzania warunkowego. W poniższym przykładzie porównamy dwie zmienne i odpowiednio dostarczymy wymagane dane wyjściowe.

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
}

Powyższy fragment kodu daje w wyniku następujące dane wyjściowe w przeglądarce. Nasz przykład zawiera również inny wiersz kodu, który przedstawia sposób użycia“If” instrukcja jako wyrażenie.

Maximum of a or b is 5

Korzystanie z When

Jeśli znasz inne języki programowania, być może słyszałeś o wyrażeniu instrukcja switch, która jest w zasadzie operatorem warunkowym, gdy do określonej zmiennej można zastosować wiele warunków. “when”operator dopasowuje wartość zmiennej do warunków gałęzi. Jeśli spełnia warunek gałęzi, wykona instrukcję w tym zakresie. W poniższym przykładzie dowiemy się więcej o „kiedy” w Kotlinie.

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

Powyższy fragment kodu daje w przeglądarce następujące dane wyjściowe.

x is neither 1 nor 2

W powyższym przykładzie kompilator Kotlin dopasowuje wartość xz podanymi gałęziami. Jeśli nie pasuje do żadnej z gałęzi, wykona inną część. Praktycznie, kiedy jest równoważne wielokrotności bloku if. Kotlin zapewnia deweloperowi dodatkową elastyczność, w której programista może zapewnić wiele kontroli w tej samej linii, zapewniając „,” wewnątrz czeków. Zmodyfikujmy powyższy przykład w następujący sposób.

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

Uruchom to samo w przeglądarce, co da w przeglądarce następujące dane wyjściowe.

x is neither 1 nor 2

Dla pętli

Pętla jest takim wynalazkiem, który zapewnia elastyczność iteracji w dowolnej strukturze danych. Podobnie jak inne języki programowania, Kotlin zapewnia również wiele rodzajów metodologii pętli, jednak wśród nich“For”jest najbardziej udany. Implementacja i użycie pętli For jest koncepcyjnie podobne do pętli for w języku Java. Poniższy przykład pokazuje, jak możemy użyć tego samego w przykładach z życia.

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

W powyższym fragmencie kodu zadeklarowaliśmy jedną listę nazwaną „items” i za pomocą pętli for iterujemy tę zdefiniowaną listę i wypisujemy jej wartość w przeglądarce. Poniżej przedstawiono dane wyjściowe.

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

Poniżej znajduje się kolejny przykład kodu, w którym używamy pewnych funkcji bibliotecznych, aby nasza praca programistyczna była łatwiejsza niż kiedykolwiek wcześniej.

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

Po skompilowaniu i wykonaniu powyższego fragmentu kodu w naszym środowisku kodowania, w przeglądarce pojawi się następujący wynik.

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 i Do-While Loop

While i Do-While działają dokładnie w podobny sposób, jak w innych językach programowania. Jedyną różnicą między tymi dwoma pętlami jest to, że w przypadku pętli Do-while warunek zostanie przetestowany na końcu pętli. Poniższy przykład pokazuje użycieWhile loop.

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

Powyższy fragment kodu daje w przeglądarce następujące dane wyjściowe.

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

Kotlin ma również inną pętlę zwaną pętlą Do-While, w której treść pętli zostanie wykonana raz, tylko wtedy zostanie sprawdzony warunek. Poniższy przykład pokazuje użycieDo-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)
}

Powyższy fragment kodu daje w przeglądarce następujące dane wyjściowe. W powyższym kodzie kompilator Kotlin wykona blok DO, a następnie przejdzie do sprawdzania warunków podczas bloku.

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

Korzystanie z opcji Return, Break, Continue

Jeśli znasz jakiś język programowania, musisz mieć pojęcie o różnych słowach kluczowych, które pomogą nam wdrożyć dobry przepływ sterowania w aplikacji. Poniżej przedstawiono różne słowa kluczowe, których można użyć do sterowania pętlami lub innymi typami przepływu sterowania.

Return- Return to słowo kluczowe, które zwraca pewną wartość do funkcji wywołującej z wywołanej funkcji. W poniższym przykładzie zaimplementujemy ten scenariusz przy użyciu naszego środowiska kodowania Kotlin.

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

W powyższym fragmencie kodu wywołujemy inną funkcję i mnożymy dane wejściowe przez 2 i zwracamy wynikową wartość do wywołanej funkcji, która jest naszą główną funkcją. Kotlin inaczej definiuje funkcję, której przyjrzymy się w kolejnym rozdziale. Na razie wystarczy zrozumieć, że powyższy kod wygeneruje w przeglądarce następujący wynik.

The value of X is--20

Continue & Break- Kontynuacja i przerwa to najważniejsze elementy logicznego problemu. Słowo kluczowe „break” przerywa przepływ sterownika, jeśli jakiś warunek zawiódł, a „continue” działa odwrotnie. Cała ta operacja odbywa się z natychmiastową widocznością. Kotlin jest mądrzejszy niż inne języki programowania, w których programista może zastosować więcej niż jedną etykietę jako widoczność. Poniższy fragment kodu pokazuje, jak wdrażamy tę etykietę w Kotlinie.

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

Powyższy fragment kodu daje w przeglądarce następujące dane wyjściowe.

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

Jak widać, sterownik kontynuuje pętlę, aż do i chyba że zostanie osiągnięta wartość x wynosi 5. Gdy wartość x osiągnie 5, rozpoczyna wykonywanie bloku if, a po osiągnięciu instrukcji break cały przepływ sterowania kończy wykonywanie programu.

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 encji środowiska wykonawczego, 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 składowych 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 () z 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, gdzie 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ł obsługę aliasów typów, jednak jeśli używasz starej wersji Kotlin, możesz używać jej w następujący sposób -

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

W tym rozdziale dowiemy się o konstruktorach w Kotlinie. Kotlin ma dwa typy konstruktorów - jeden toprimary constructor a drugi to secondary constructor. Jedna klasa Kotlin może mieć jednego konstruktora podstawowego i jednego lub więcej konstruktorów pomocniczych. Konstruktor Java inicjuje zmienne składowe, jednak w Kotlinie główny konstruktor inicjuje klasę, podczas gdy konstruktor pomocniczy pomaga uwzględnić dodatkową logikę podczas inicjowania tego samego. Konstruktor podstawowy można zadeklarować na poziomie nagłówka klasy, jak pokazano w poniższym przykładzie.

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

W powyższym przykładzie zadeklarowaliśmy główny konstruktor wewnątrz nawiasów. Wśród dwóch pól imię jest tylko do odczytu, ponieważ jest zadeklarowane jako „val”, podczas gdy wiek pola można edytować. W poniższym przykładzie użyjemy konstruktora podstawowego.

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

Powyższy fragment kodu automatycznie zainicjuje dwie zmienne i wyświetli następujące dane wyjściowe w przeglądarce.

First Name = TutorialsPoint.com
Age = 15

Jak wspomniano wcześniej, Kotlin pozwala na utworzenie jednego lub więcej konstruktorów pomocniczych dla Twojej klasy. Ten konstruktor pomocniczy jest tworzony za pomocą słowa kluczowego „constructor”. Jest to wymagane, gdy chcesz utworzyć więcej niż jeden konstruktor w Kotlinie lub gdy chcesz zawrzeć więcej logiki w konstruktorze podstawowym i nie możesz tego zrobić, ponieważ konstruktor podstawowy może być wywoływany przez inną klasę. Spójrz na poniższy przykład, w którym utworzyliśmy pomocniczy konstruktor i używamy powyższego przykładu do implementacji tego samego.

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 - Można utworzyć dowolną liczbę konstruktorów pomocniczych, jednak wszystkie te konstruktory powinny wywoływać konstruktor główny bezpośrednio lub pośrednio.

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

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

W tym rozdziale dowiemy się o dziedziczeniu. Z definicji wszyscy wiemy, że dziedziczenie oznacza przeniesienie pewnych właściwości klasy matki do klasy potomnej. W Kotlinie klasa bazowa nosi nazwę „Any”, która jest nadrzędną klasą domyślnej klasy „any” zadeklarowanej w Kotlinie. Podobnie jak wszystkie inne OOPS, Kotlin również zapewnia tę funkcjonalność za pomocą jednego słowa kluczowego znanego jako“:”.

Wszystko w Kotlinie jest domyślnie ostateczne, dlatego musimy użyć słowa kluczowego „open” przed deklaracją klasy, aby umożliwić dziedziczenie. Spójrz na poniższy przykład dziedziczenia.

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

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

Hey!! i am thiking

A co, jeśli chcemy przesłonić metodę think () w klasie potomnej. Następnie musimy rozważyć następujący przykład, w którym tworzymy dwie klasy i nadpisujemy jedną z jej funkcji na klasę potomną.

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

Powyższy fragment kodu wywoła dziedziczoną metodę klasy potomnej i da w przeglądarce następujący wynik. Podobnie jak Java, Kotlin również nie pozwala na wielokrotne dziedziczenie.

I Am from Child

W tym rozdziale dowiemy się o interfejsie w Kotlinie. W Kotlinie interfejs działa dokładnie podobnie jak w Javie 8, co oznacza, że ​​może zawierać zarówno implementację metody, jak i deklarację metod abstrakcyjnych. Interfejs może zostać zaimplementowany przez klasę w celu wykorzystania zdefiniowanej funkcjonalności. Przykład z interfejsem przedstawiliśmy już w rozdziale 6 - sekcja „anonimowa klasa wewnętrzna”. W tym rozdziale dowiemy się więcej na ten temat. Słowo kluczowe „interfejs” służy do zdefiniowania interfejsu w Kotlinie, jak pokazano w poniższym fragmencie kodu.

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

W powyższym przykładzie utworzyliśmy jeden interfejs nazwany „ExampleInterface”, a wewnątrz niego mamy kilka abstrakcyjnych właściwości i metod. Spójrz na funkcję o nazwie „sayHello ()”, która jest zaimplementowaną metodą.

W poniższym przykładzie zaimplementujemy powyższy interfejs w klasie.

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

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

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

Jak wspomniano wcześniej, Kotlin nie obsługuje wielu dziedziczenia, jednak to samo można osiągnąć, implementując więcej niż dwa interfejsy naraz.

W poniższym przykładzie utworzymy dwa interfejsy, a później zaimplementujemy oba interfejsy do klasy.

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

W powyższym przykładzie stworzyliśmy dwa przykładowe interfejsy A, B, aw klasie o nazwie „multipleInterfaceExample” zaimplementowaliśmy dwa zadeklarowane wcześniej interfejsy. Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce.

method of interface A
I am another Method from interface B

W tym rozdziale poznamy różne modyfikatory dostępne w języku Kotlin. Access modifiersłuży do ograniczenia użycia zmiennych, metod i klas używanych w aplikacji. Podobnie jak w przypadku innych języków programowania OOP, ten modyfikator ma zastosowanie w wielu miejscach, takich jak nagłówek klasy lub deklaracja metody. W Kotlinie dostępne są cztery modyfikatory dostępu.

Prywatny

Klasy, metody i pakiety można zadeklarować za pomocą prywatnego modyfikatora. Gdy cokolwiek zostanie zadeklarowane jako prywatne, będzie dostępne w swoim bezpośrednim zasięgu. Na przykład pakiet prywatny może być dostępny w ramach tego konkretnego pliku. Klasa prywatna lub interfejs mogą być dostępne tylko dla jej członków danych itp.

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

W powyższym przykładzie klasa “privateExample” a zmienna i both może być dostępna tylko w tym samym pliku Kotlin, gdzie została wspomniana, ponieważ wszystkie są zadeklarowane jako prywatne w bloku deklaracji.

Chroniony

Protected to kolejny modyfikator dostępu dla Kotlin, który obecnie nie jest dostępny dla deklaracji najwyższego poziomu, tak jak żaden pakiet nie może być chroniony. Chroniona klasa lub interfejs jest widoczny tylko dla jej podklasy.

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

W powyższym przykładzie zmienna “i” jest zadeklarowany jako chroniony, dlatego jest widoczny tylko dla swojej podklasy.

Wewnętrzny

Internal to nowo dodany modyfikator wprowadzony w Kotlinie. Jeśli cokolwiek jest oznaczone jako wewnętrzne, to konkretne pole będzie znajdować się w polu wewnętrznym. Pakiet wewnętrzny jest widoczny tylko wewnątrz modułu, w ramach którego jest zaimplementowany. Wewnętrzny interfejs klasy jest widoczny tylko przez inną klasę obecną w tym samym pakiecie lub module. W poniższym przykładzie zobaczymy, jak zaimplementować metodę wewnętrzną.

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

W powyższym przykładzie metoda o nazwie „doSomething” i zmienna jest wymieniona jako wewnętrzna, stąd te dwa pola mogą być dostępne tylko wewnątrz pakietu, w którym jest zadeklarowana.

Publiczny

Modyfikator publiczny jest dostępny z dowolnego miejsca w obszarze roboczym projektu. Jeśli nie określono modyfikatora dostępu, domyślnie będzie on miał zasięg publiczny. We wszystkich naszych poprzednich przykładach nie wspomnieliśmy o żadnym modyfikatorze, dlatego wszystkie są w zakresie publicznym. Poniżej znajduje się przykład, aby dowiedzieć się więcej na temat deklarowania publicznej zmiennej lub metody.

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

W powyższym przykładzie nie wymieniliśmy żadnego modyfikatora, dlatego wszystkie te metody i zmienne są domyślnie publiczne.

W tym rozdziale dowiemy się o kolejnej nowej funkcji Kotlina o nazwie „Rozszerzenie”. Korzystając z rozszerzenia, będziemy mogli dodawać lub usuwać niektóre funkcje metod, nawet bez ich dziedziczenia lub modyfikowania. Rozszerzenia są rozwiązywane statystycznie. W rzeczywistości nie modyfikuje istniejącej klasy, ale tworzy wywoływalną funkcję, którą można wywołać za pomocą operacji kropkowej.

Rozszerzenie funkcji

W rozszerzeniu funkcji Kotlin pozwala zdefiniować metodę poza główną klasą. W poniższym przykładzie zobaczymy, jak rozszerzenie jest wdrażane na poziomie funkcjonalnym.

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
}

W powyższym przykładzie nie mamy żadnej metody wewnątrz klasy „Alien” o nazwie „addMySkills ()”, jednak nadal wdrażamy tę samą metodę gdzieś poza klasą. To jest magia rozszerzenia.

Powyższy fragment kodu wygeneruje następujące dane wyjściowe w przeglądarce.

JAVA SQL

Rozszerzenie obiektu

Kotlin zapewnia kolejny mechanizm implementacji statycznej funkcjonalności Javy. Można to osiągnąć za pomocą słowa kluczowego „obiekt towarzyszący”. Korzystając z tego mechanizmu, możemy stworzyć obiekt klasy wewnątrz metody fabrycznej, a później możemy po prostu wywołać tę metodę, używając odwołania do nazwy klasy. W poniższym przykładzie utworzymy „obiekt towarzyszący”.

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

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

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

Powyższy przykład wydaje się statyczny w Javie, jednak w czasie rzeczywistym tworzymy obiekt jako zmienną składową tej samej klasy. Z tego powodu jest on również zawarty we właściwości rozszerzenia i może być alternatywnie nazywany rozszerzeniem obiektu. Zasadniczo rozszerzasz obiekt tej samej klasy, aby użyć niektórych funkcji składowych.

W tym rozdziale dowiemy się więcej o klasach danych języka programowania Kotlin. Klasa może być oznaczona jako klasa danych zawsze wtedy, gdy jest oznaczona jako „data”. Tego typu klasy można użyć do oddzielenia podstawowych danych. Poza tym nie zapewnia żadnej innej funkcjonalności.

Wszystkie klasy danych muszą mieć jeden główny konstruktor, a wszystkie podstawowe konstruktory powinny mieć co najmniej jeden parametr. Za każdym razem, gdy klasa jest oznaczona jako dane, możemy użyć niektórych wbudowanych funkcji tej klasy danych, takich jak „toString ()”, „hashCode ()” itp. Żadna klasa danych nie może mieć modyfikatora, takiego jak abstract i open lub internal. Klasę danych można również rozszerzyć na inne klasy. W poniższym przykładzie utworzymy jedną klasę danych.

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)

Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce, w której utworzyliśmy jedną klasę danych do przechowywania niektórych danych, a z głównej funkcji uzyskaliśmy dostęp do wszystkich jej składowych danych.

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

W tym rozdziale poznamy inny typ klasy zwany klasą „zapieczętowaną”. Ten typ klasy służy do reprezentowania ograniczonej hierarchii klas. Sealed umożliwia programistom zachowanie typu danych o predefiniowanym typie. Aby utworzyć zapieczętowaną klasę, musimy użyć słowa kluczowego „seal” jako modyfikatora tej klasy. Klasa zapieczętowana może mieć własną podklasę, ale wszystkie te podklasy muszą być zadeklarowane w tym samym pliku Kotlin wraz z klasą zapieczętowaną. W poniższym przykładzie zobaczymy, jak używać zapieczętowanej klasy.

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

W powyższym przykładzie mamy jedną zapieczętowaną klasę o nazwie „MyExample”, która może mieć tylko dwa typy - jeden to „OP1”, a drugi to „OP2”. W klasie głównej tworzymy obiekt w naszej klasie i przypisujemy jego typ w czasie wykonywania. Teraz, ponieważ ta klasa „MyExample” jest zapieczętowana, możemy zastosować klauzulę „when” w czasie wykonywania, aby zaimplementować ostateczne dane wyjściowe.

W klasie zapieczętowanej nie musimy używać żadnych niepotrzebnych instrukcji „else” w celu skompleksowania kodu. Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce.

option Two has been chosen

Podobnie jak Java, Kotlin zapewnia wyższą kolejność typowania zmiennych nazywaną rodzajami. W tym rozdziale dowiemy się, w jaki sposób Kotlin implementuje Generics i jak jako programista możemy korzystać z funkcji dostępnych w bibliotece generics. Jeśli chodzi o implementację, generics jest bardzo podobny do Java, ale programista Kotlin wprowadził dwa nowe słowa kluczowe“out” i “in” aby uczynić kody Kotlin bardziej czytelnymi i łatwiejszymi dla programistów.

W Kotlinie klasa i typ to zupełnie inne pojęcia. Jak na przykładzie, List jest klasą w Kotlin, podczas gdy List <String> jest typem w Kotlin. Poniższy przykład przedstawia sposób implementacji typów generycznych w Kotlin.

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

W powyższym kodzie zadeklarowaliśmy jedną „liczbę całkowitą”, a później przypisaliśmy tę zmienną do zmiennej liczbowej. Jest to możliwe, ponieważ „Int” jest podklasą klasy Number, stąd konwersja typu następuje automatycznie w czasie wykonywania i generuje wynik jako „1”.

Nauczmy się czegoś więcej o generykach w Kotlinie. Lepiej jest wybierać ogólny typ danych, gdy nie jesteśmy pewni, jakiego typu danych będziemy używać w aplikacji. Ogólnie rzecz biorąc, w Kotlin typy generyczne są zdefiniowane przez<T>gdzie „T” oznacza szablon, który może być określony dynamicznie przez firmę Kotlin. W poniższym przykładzie zobaczymy, jak używać ogólnych typów danych w języku programowania Kotlin.

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

W powyższym fragmencie kodu tworzymy jedną klasę z ogólnym typem zwracanym, który jest reprezentowany jako <T>. Przyjrzyj się głównej metodzie, w której dynamicznie zdefiniowaliśmy jej wartość w trakcie, udowadniając typ wartości, podczas tworzenia obiektu tej klasy. Oto jak typy generyczne są interpretowane przez kompilator Kotlin. Otrzymamy następujące dane wyjściowe w przeglądarce, gdy uruchomimy ten kod w naszym obszarze kodowania.

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

Kiedy chcemy przypisać typ ogólny do dowolnego z jego supertypów, musimy użyć słowa kluczowego „out”, a kiedy chcemy przypisać typ ogólny do dowolnego z jego podtypów, musimy użyć „in” słowo kluczowe. W poniższym przykładzie użyjemy słowa kluczowego „out”. Podobnie możesz spróbować użyć słowa kluczowego „in”.

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

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

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

Kotlin wspiera “delegation” wzorzec projektowy poprzez wprowadzenie nowego słowa kluczowego “by”. Używając tego słowa kluczowego lub metodologii delegowania, Kotlin umożliwia klasie pochodnej dostęp do wszystkich zaimplementowanych metod publicznych interfejsu za pośrednictwem określonego obiektu. Poniższy przykład pokazuje, jak to się dzieje w Kotlinie.

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 
}

W tym przykładzie mamy jeden interfejs „Base” z abstrakcyjną metodą o nazwie „printme ()”. W klasie BaseImpl implementujemy tę „printme ()”, a później z innej klasy używamy tej implementacji za pomocą słowa kluczowego „by”.

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

10

Delegowanie własności

W poprzedniej sekcji dowiedzieliśmy się o wzorcu projektowym delegowania przy użyciu słowa kluczowego „by”. W tej sekcji dowiemy się o delegowaniu właściwości przy użyciu standardowych metod wymienionych w bibliotece Kotlin.

Delegacja oznacza przekazanie odpowiedzialności innej klasie lub metodzie. Gdy właściwość jest już zadeklarowana w niektórych miejscach, powinniśmy ponownie użyć tego samego kodu do ich zainicjowania. W poniższych przykładach użyjemy standardowej metodologii delegowania dostarczonej przez Kotlin i niektórych standardowych funkcji bibliotecznych podczas implementowania delegacji w naszych przykładach.

Używanie Lazy ()

Lazy to funkcja lambda, która przyjmuje właściwość jako dane wejściowe i zwraca w zamian instancję Lazy<T>, gdzie <T> jest w zasadzie typem właściwości, których używa. Przyjrzyjmy się poniższym, aby zrozumieć, jak to działa.

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

W powyższym fragmencie kodu przekazujemy zmienną „myVar” do funkcji Lazy, która w zamian przypisuje wartość do swojego obiektu i zwraca ją do funkcji głównej. Poniżej przedstawiono dane wyjściowe w przeglądarce.

Hello My dear friend

Delegetion.Observable ()

Observable () pobiera dwa argumenty do inicjalizacji obiektu i zwraca je do wywoływanej funkcji. W poniższym przykładzie zobaczymy, jak użyć metody Observable () w celu zaimplementowania delegacji.

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

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

first -> second

Ogólnie składnia jest wyrażeniem występującym po delegowaniu słowa kluczowego „by”. Plikget() i set() metody zmiennej p zostanie przekazana jej getValue() i setValue() metody zdefiniowane w klasie Delegate.

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

Dla powyższego fragmentu kodu, poniżej znajduje się klasa delegata, którą musimy wygenerować, aby przypisać wartość zmiennej 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.'")
   }
}

Podczas czytania zostanie wywołana metoda getValue (), a podczas ustawiania zmiennej metoda setValue ().

Kotlin jest językiem typowanym statycznie, stąd dużą rolę odgrywają w nim funkcje. Jesteśmy dość obeznani z funkcją, ponieważ używamy funkcji w przykładach. Funkcja jest deklarowana za pomocą słowa kluczowego „fun”. Jak każdy inny obiekt OOP, potrzebuje również zwracanego typu i listy argumentów opcji.

W poniższym przykładzie definiujemy funkcję o nazwie MyFunction iz funkcji głównej wywołujemy tę funkcję i przekazujemy argument.

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

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

Hey!! Welcome To ---tutorialsPoint.com

Funkcję należy zadeklarować w następujący sposób -

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

Poniżej znajduje się kilka różnych typów funkcji dostępnych w Kotlin.

Funkcja Lambda

Lambda to funkcja wysokiego poziomu, która drastycznie redukuje kod płyty kotła podczas deklarowania funkcji i definiowania jej. Kotlin pozwala zdefiniować własną lambdę. W Kotlinie możesz zadeklarować swoją lambdę i przekazać tę lambdę do funkcji.

Spójrz na poniższy przykład.

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

W powyższym kodzie stworzyliśmy własną lambdę znaną jako „mylambda” i przekazaliśmy do niej jedną zmienną, która jest typu String i zawiera wartość „TutorialsPoint.com”.

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

TutorialsPoint.com

Funkcja inline

Powyższy przykład przedstawia podstawowe wyrażenie lambda, którego możemy użyć w aplikacji Kotlin. Teraz możemy przekazać lambdę do innej funkcji, aby uzyskać nasze dane wyjściowe, które sprawiają, że funkcja wywołująca jest funkcją wbudowaną.

Spójrz na poniższy przykład.

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
}

Powyższy fragment kodu przyniesie następujące wyniki w przeglądarce. Używając funkcji inline, przekazaliśmy lambdę jako parametr. Każda inna funkcja może być funkcją wbudowaną za pomocą słowa kluczowego „inline”.

Heyyy!!!TutorialsPoint.com

Kotlin zawiera wiele funkcji innych języków programowania. Pozwala na jednoczesne zadeklarowanie wielu zmiennych. Technika ta nosi nazwę Deklaracja destrukcji.

Poniżej przedstawiono podstawową składnię deklaracji destrukturyzacji.

val (name, age) = person

W powyższej składni utworzyliśmy obiekt i zdefiniowaliśmy je wszystkie razem w jednej instrukcji. Później możemy ich używać w następujący sposób.

println(name)
println(age)

Zobaczmy teraz, jak możemy użyć tego samego w naszej prawdziwej aplikacji. Rozważmy następujący przykład, w którym tworzymy jedną klasę Studenta z pewnymi atrybutami, a później będziemy ich używać do drukowania wartości obiektów.

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
}

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

You are learning Kotlin from TutorialsPoint.com

Obsługa wyjątków jest bardzo ważną częścią języka programowania. Ta technika ogranicza możliwości generowania przez naszą aplikację nieprawidłowych danych wyjściowych w czasie wykonywania. W tym rozdziale dowiemy się, jak obsługiwać wyjątek środowiska uruchomieniowego w Kotlin. Wyjątki w Kotlinie są bardzo podobne do wyjątków w Javie. Wszystkie wyjątki to potomkowie klasy „Throwable”. Poniższy przykład pokazuje, jak używać techniki obsługi wyjątków w Kotlin.

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

W powyższym fragmencie kodu zadeklarowaliśmy String, a później powiązaliśmy ten ciąg z liczbą całkowitą, która w rzeczywistości jest wyjątkiem w czasie wykonywania. W związku z tym w przeglądarce otrzymamy następujące dane wyjściowe.

val myVar:Int = 12;
Exception Handeling in Kotlin

Note - Podobnie jak Java, Kotlin również wykonuje ostatni blok po wykonaniu bloku catch.