h1. Kotlin

[Kotlin|https://kotlinlang.org] - это универсальный язык программирования, созданный [JetBrains|https://www.jetbrains.com] в качестве альтернативы Java с намного более удобным синтаксисом, но выполняющийся на JVM и полностью совместимый с существующей экосистемой Java.

Поддержка языка уже доступна из коробки в [ItelliJ IDEA|https://www.jetbrains.com/idea/] от JetBrains и [Android Studio|https://developer.android.com/studio/] от Google. Поэтому перспективы внушительные. См. про это в блоге: [Kotlin 1.0 Released: Pragmatic Language for JVM and Android|https://blog.jetbrains.com/kotlin/2016/02/kotlin-1-0-released-pragmatic-language-for-jvm-and-android/].
Kotlin уже стал [официальным|https://blog.jetbrains.com/kotlin/2017/05/kotlin-on-android-now-official/] и [предпочтительным|https://techcrunch.com/2019/05/07/kotlin-is-now-googles-preferred-language-for-android-app-development/] языком для Android и [официальным языком соревнований ACM ICPC|http://codeforces.com/blog/entry/52128?locale=ru#comment-361660].

[Официальная справка по языку|https://kotlinlang.org/docs/reference/] ([по-русски|https://kotlinlang.ru/])
A Comprehensive Kotlin Learning Guide for All Levels: https://blog.jetbrains.com/education/2024/04/04/kotlin-learning-guide/
[Краткое описание по русски|https://vk.com/pages?oid=-59097513&p=%D0%92%D0%B2%D0%B5%D0%B4%D0%B5%D0%BD%D0%B8%D0%B5_%D0%B2_%D1%8F%D0%B7%D1%8B%D0%BA_Kotlin]
[Хабрахабр: Почему следует полностью переходить на Kotlin|https://habrahabr.ru/company/mailru/blog/329294/] (список фич)
*Осторожно*, опросы показывают, что Kotlin вызывает привыкание: https://insights.stackoverflow.com/survey/2019#technology-_-most-loved-dreaded-and-wanted-languages

*Видео* по-русски: [Что такое Kotlin? Введение|https://www.youtube.com/watch?v=HWyd1gYMkl0], [Введение в Kotlin|https://www.youtube.com/watch?v=QBE7My-ZoQU], [Идиоматичный Kotlin|https://www.youtube.com/watch?v=2raT3QX3aNg], [Корутины в Kotlin|https://www.youtube.com/watch?v=rB5Q3y73FTo]
[Вводные видео|http://petersommerhoff.com/dev/kotlin/kotlin-beginner-tutorial/]
[Серия видеоуроков|https://habrahabr.ru/post/321600/] ([playlist|https://www.youtube.com/playlist?list=PLIU76b8Cjem4ZOt3tlWykUX1AjL9zE19t])

*Видео* по-английски + livecoding: [How to Kotlin|https://www.youtube.com/watch?v=6P20npkvcb8], [Kotlin: Ready for Production|https://academy.realm.io/posts/gotocph-hadi-hariri-kotlin-ready-for-production/], [Functional Programming with Kotlin|https://www.youtube.com/watch?v=eNe5Nokrjdg], [Kotlin 102 - Beyond the Basics|https://www.youtube.com/watch?v=1KldcFc7HCY], [Kotlin/Anywhere|https://www.youtube.com/watch?v=v96mVdcZd1g], [Kotlin in Space|https://www.youtube.com/watch?v=JnmHqKLgYY4]
Coroutines: [Introduction to Coroutines|https://www.youtube.com/watch?v=_hfBv0a09Jc], [Kotlin Coroutines in Practice|https://www.youtube.com/watch?v=a3agLJQ6vt8], [Server-side Kotlin with Coroutines|https://www.youtube.com/watch?v=hQrFfwT1IMo].

*Введения*:
[Habr: Андрей Бреслав и Дмитрий Жемеров о Kotlin 1.0|https://habrahabr.ru/post/279667/] (внутри много ссылок).
https://superkotlin.com/kotlin-mega-tutorial/
Интересные иллюстрированные введения в концепции языка (англ.): https://typealias.com

*Книги*:
* [Kotlin в действии|https://ru.pdfdrive.com/kotlin-%D0%B2-%D0%B4%D0%B5%D0%B9%D1%81%D1%82%D0%B2%D0%B8%D0%B8-d187850272.html]
* [Atomic Kotlin|https://www.atomickotlin.com/] ([скачать|https://dokumen.pub/atomic-kotlin-9780981872544-9780981872551.html])
* [Hands-On Design Patterns with Kotlin|https://codernet.ru/books/kotlin/hands-on_design_patterns_with_kotlin/]

*Курсы*:
[Бесплатные курсы по Kotlin на Stepik|https://stepik.org/catalog?q=Kotlin], https://www.coursera.org/learn/vvedenie-v-yazyk-kotlin
Coursera: [Kotlin for Java Developers|https://coursera.org/learn/kotlin-for-java-developers]
JetBrains Academy: free adaptive track [Kotlin Basics|https://hyperskill.org/tracks/18]
[Algorithms and data structures in Kotlin|https://github.com/bmaslakov/kotlin-algorithm-club]
[Kotlin Academy|https://kotlin-academy.herokuapp.com/]

*Песочница*: На сайтах https://play.kotlinlang.org/ и http://try.kotlinlang.org/ есть набор ознакомительных задач и можно запускать решения на Kotlin прямо в браузере.
Большой набор набор ссылок по продвинутому использованию Kotlin: http://kotlin.link/.
https://developer.android.com/kotlin/resources.html

Вот отчёт о первом Kotlin Challenge с Геной и примером решения: https://habrahabr.ru/company/JetBrains/blog/222693/.
Больше идеоматических примеров решения задач можно найти в [Codeforces Surprise Language Round #8|http://codeforces.com/blog/entry/45454?#comment-300490] и http://rosettacode.org/wiki/Category:Kotlin.

[Как писать в файл|http://stackoverflow.com/questions/35444264/how-do-i-write-to-a-file-in-kotlin/].
[Примеры обращения с коллекциями|http://stackoverflow.com/questions/34642254/what-java-8-stream-collect-equivalents-are-available-in-the-standard-kotlin-libr].
[Функциональное программирование на Kotlin|https://habrahabr.ru/post/268463/].
[Kotlin Coding Conventions|https://kotlinlang.org/docs/reference/coding-conventions.html].

Ещё тренироваться в решении задач на Kotlin можно на http://codeforces.com, https://www.hackerrank.com, https://www.codechef.com, https://codingame.com, [Advent of Code|https://blog.jetbrains.com/kotlin/2015/12/try-kotlin-with-advent-of-code/] и в курсе Программирование \ Программирование на Java на [DL|http://dl.gsu.by].

Для корректного тестирования на DL в тексте решения на Kotlin должна быть определена функция верхнего уровня main:
{code}
fun main() {
println("Hello world!")
}
{code}

[Примеры|https://stackoverflow.com/questions/41283393/reading-console-input-in-kotlin] *A+B*
{code}
fun main() {
val (a, b) = readLine()!!.split(' ')
println(a.toInt() + b.toInt())
}
{code}
или
{code}
fun main() {
val (a, b) = readLine()!!.split(' ').map { it.toInt() }
println(a + b)
}
{code}
или (из https://kotlinlang.org/docs/tutorials/competitive-programming.html)
{code}

fun readLn() = readLine()!! // string line
fun readInt() = readLn().toInt() // single int
fun readStrings() = readLn().split(" ") // list of strings
fun readInts() = readStrings().map { it.toInt() } // list of ints

fun main(vararg args: String) {
val (a, b) = readInts()
println(a + b)
}
{code}
или
{code}
import java.util.Scanner

fun main() {
val input = Scanner(System.`in`)
val a = input.nextInt()
val b = input.nextInt()
println(a + b)
}
{code}
или
{code}
import java.util.Scanner

fun main() {
with(Scanner(System.`in`)) {
val a = nextInt()
val b = nextInt()
println(a + b)
}
}
{code}

Чтение/запись в файл:

{code}
fun <T : Closeable, R> T.useWith(block: T.() -> R): R = use { with(it, block) }

File("a.in").bufferedReader().useWith {
File("a.out").printWriter().useWith {
val (a, b) = readLine()!!.split(' ').map(String::toInt)
println(a + b)
}
}

Scanner(File("b.in")).useWith {
PrintWriter("b.out").useWith {
val a = nextInt()
val b = nextInt()
println(a + b)
}
}
{code}