Kotlin - podstawowe typy

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, są niezmienne z natury. 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()itp. 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 następujące wyniki w przeglądarce.

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 następujące wyniki w przeglądarce.

1234we found your number --2