Kotlin - Grundtypen

In diesem Kapitel lernen wir die grundlegenden Datentypen kennen, die in der Programmiersprache Kotlin verfügbar sind.

Zahlen

Die Darstellung von Zahlen in Kotlin ist Java ziemlich ähnlich, Kotlin erlaubt jedoch keine interne Konvertierung verschiedener Datentypen. In der folgenden Tabelle sind verschiedene variable Längen für verschiedene Zahlen aufgeführt.

Art Größe
Doppelt 64
Schweben 32
Lange 64
Int 32
Kurz 16
Byte 8

Im folgenden Beispiel sehen wir, wie Kotlin mit verschiedenen Datentypen arbeitet. Bitte geben Sie den folgenden Code in unseren Codierungsbereich ein.

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

Wenn Sie den obigen Code im Codierungsfeld ausführen, wird die folgende Ausgabe in der Webkonsole generiert.

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

Zeichen

Kotlin repräsentiert Charakter mit char. Zeichen sollte in einem einfachen Anführungszeichen wie deklariert werden‘c’. Bitte geben Sie den folgenden Code in unseren Codierungsgrund ein und sehen Sie, wie Kotlin die Zeichenvariable interpretiert. Zeichenvariable kann nicht wie Zahlenvariable deklariert werden. Die Kotlin-Variable kann auf zwei Arten deklariert werden - eine mit“var” und eine andere Verwendung “val”.

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

Der obige Code liefert die folgende Ausgabe im Browser-Ausgabefenster.

A

Boolescher Wert

Boolean ist wie andere Programmiersprachen sehr einfach. Wir haben nur zwei Werte für Boolean - entweder wahr oder falsch. Im folgenden Beispiel werden wir sehen, wie Kotlin Boolean interpretiert.

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

Der obige Code liefert die folgende Ausgabe im Browser.

Your character value is true

Saiten

Zeichenfolgen sind Zeichenarrays. Wie Java sind sie von Natur aus unveränderlich. Wir haben zwei Arten von Zeichenfolgen in Kotlin - eine heißtraw String und ein anderer heißt escaped String. Im folgenden Beispiel werden wir diese Zeichenfolgen verwenden.

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

Das obige Beispiel für einen maskierten String ermöglicht es, nach der ersten print-Anweisung zusätzlichen Zeilenabstand bereitzustellen. Es folgt die Ausgabe im Browser.

Hello!I am escaped String!

Hey!!I am Raw String!

Arrays

Arrays sind eine Sammlung homogener Daten. Wie Java unterstützt Kotlin Arrays verschiedener Datentypen. Im folgenden Beispiel werden verschiedene Arrays verwendet.

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

Der obige Code liefert die folgende Ausgabe. Die Indizierung des Arrays ähnelt anderen Programmiersprachen. Hier suchen wir nach einem zweiten Index, dessen Wert "3" ist.

Hey!! I am array Example3

Sammlungen

Die Erfassung ist ein sehr wichtiger Teil der Datenstruktur, der Ingenieuren die Softwareentwicklung erleichtert. Kotlin hat zwei Arten von Sammlungen - eine istimmutable collection (was bedeutet, Listen, Karten und Sets, die nicht bearbeitet werden können) und eine andere ist mutable collection(Diese Art der Sammlung kann bearbeitet werden). Es ist sehr wichtig, die Art der in Ihrer Anwendung verwendeten Sammlung zu berücksichtigen, da das Kotlin-System keinen spezifischen Unterschied zwischen ihnen darstellt.

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  
}

Der obige Code liefert die folgende Ausgabe im Browser. Es gibt einen Fehler, wenn wir versuchen, die veränderbare Liste der Sammlung zu löschen.

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

In der Sammlung bietet Kotlin einige nützliche Methoden wie first(), last(), filter()usw. Alle diese Methoden sind selbstbeschreibend und einfach zu implementieren. Darüber hinaus folgt Kotlin bei der Implementierung der Sammlung der gleichen Struktur wie Java. Sie können jede Sammlung Ihrer Wahl wie Map und Set implementieren.

Im folgenden Beispiel haben wir Map und Set mit verschiedenen integrierten Methoden implementiert.

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

Der obige Code liefert die folgende Ausgabe im Browser.

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]

Bereiche

Ranges ist ein weiteres einzigartiges Merkmal von Kotlin. Wie Haskell bietet es einen Operator, mit dem Sie einen Bereich durchlaufen können. Intern wird es mit implementiertrangeTo() und seine Operatorform ist (..).

Im folgenden Beispiel sehen wir, wie Kotlin diesen Bereichsoperator interpretiert.

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

Der obige Code liefert die folgende Ausgabe im Browser.

1234we found your number --2