Strings
String Equality
Section titled “String Equality”In Kotlin strings are compared with == operator which chect for their structural equality.
val str1 = "Hello, World!"val str2 = "Hello," + " World!"println(str1 == str2) // Prints trueReferential equality is checked with === operator.
val str1 = """ |Hello, World! """.trimMargin()
val str2 = """ #Hello, World! """.trimMargin("#")
val str3 = str1
println(str1 == str2) // Prints trueprintln(str1 === str2) // Prints falseprintln(str1 === str3) // Prints trueString Literals
Section titled “String Literals”Kotlin has two types of string literals:
- Escaped string
- Raw string
Escaped string handles special characters by escaping them. Escaping is done with a backslash. The following escape sequences are supported: \t, \b, \n, \r, \', \", \\ and \$. To encode any other character, use the Unicode escape sequence syntax: \uFF00.
val s = "Hello, world!\n"Raw string delimited by a triple quote """, contains no escaping and can contain newlines and any other characters
val text = """ for (c in "foo") print(c)"""Leading whitespace can be removed with trimMargin() function.
val text = """ |Tell me and I forget. |Teach me and I remember. |Involve me and I learn. |(Benjamin Franklin) """.trimMargin()Default margin prefix is pipe character |, this can be set as a parameter to trimMargin; e.g. trimMargin(">").
Elements of String
Section titled “Elements of String”Elements of String are characters that can be accessed by the indexing operation
string[index].
val str = "Hello, World!"println(str[1]) // Prints eString elements can be iterated with a for-loop.
for (c in str) { println(c)}String Templates
Section titled “String Templates”Both escaped strings and raw strings can contain template expressions. Template expression is a piece of code which is evaluated and its result is concatenated into string. It starts with a dollar sign $ and consists of either a variable name:
val i = 10val s = "i = $i" // evaluates to "i = 10"Or an arbitrary expression in curly braces:
val s = "abc"val str = "$s.length is ${s.length}" // evaluates to "abc.length is 3"To include a literal dollar sign in a string, escape it using a backslash:
val str = "\$foo" // evaluates to "$foo"The exception is raw strings, which do not support escaping. In raw strings you can use the following syntax to represent a dollar sign.
val price = """${'$'}9.99"""