Anonymous Quiz
46%
Объявляя функцию, которая возвращает другую функцию
38%
Использование лямбда-выражений внутри функции
7%
Применение функционального интерфейса
9%
Использование ключевых слов `fun` и `return`
💊10🤔3
Anonymous Quiz
94%
Потому что он принудительно преобразует nullable тип в non-nullable
2%
Потому что это замедляет работу приложения
3%
Потому что это усложняет чтение кода
1%
Потому что он несовместим с большинством API Kotlin
Это объект управления корутиной, который:
- Хранит состояние корутины (активна, завершена, отменена).
- Связан с родительским контекстом (child-parent Job).
- Позволяет управлять жизненным циклом (отмена, ожидание завершения).
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2🔥1
Anonymous Quiz
6%
private
14%
protected
79%
internal
1%
public
🤔2👍1
Anonymous Quiz
79%
listOf(1)
4%
setOf(1)
5%
mutableListOf(1)
12%
arrayOf(1)
💊10🤯2👀1
1. Try-catch внутри launch {} или async {} – локальная обработка ошибок.
2. CoroutineExceptionHandler – глобальная обработка в launch, но не работает с async.
3. supervisorScope {} – дочерние корутины не завершают родительский scope при ошибке.
4. try-catch вокруг await() – обработка исключений из async.
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2
Anonymous Quiz
3%
Компиляция успешно пройдет
2%
Значение переменной будет изменено
94%
Произойдет ошибка компиляции
1%
Переменная станет `var`
Anonymous Quiz
81%
super()
13%
this()
3%
base()
2%
parent()
Да, есть.
- В launch {} ошибка автоматически передается вверх и может быть обработана CoroutineExceptionHandler.
- В async {} ошибки НЕ передаются автоматически, они остаются внутри Deferred<T>.
- Чтобы поймать ошибку в async {}, нужно вызвать await() внутри try-catch.
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥6
Anonymous Quiz
54%
intArrayOf(1, 2, 3)
8%
arrayOfInt(1, 2, 3)
30%
Array<Int>(1, 2, 3)
8%
List<Int>(1, 2, 3)
👍1
Anonymous Quiz
8%
clone()
86%
copy()
3%
replicate()
3%
duplicate()
Оба создают новый scope, но различие в обработке ошибок:
- coroutineScope {} – если одна дочерняя корутина упадет, отменяются все остальные.
- supervisorScope {} – если одна корутина упадет, остальные продолжают работу.
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3👍2
Anonymous Quiz
95%
Потому что автоматически генерирует методы `equals()`, `hashCode()`, и `toString()`
1%
Потому что такие классы быстрее работают
2%
Потому что они могут хранить больше данных, чем обычные классы
2%
Потому что они лучше интегрируются с базами данных
Anonymous Quiz
22%
internal
65%
private
11%
protected
2%
public
Scope получает сигнал отмены через isActive и CancellationException.
1. Проверка isActive – корутина может проверять свое состояние.
2. Бросок CancellationException – если корутина cancel(), все suspend-функции выбросят исключение.
3. Корутине может передаваться Job, который автоматически отменяется с Scope.
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1
Anonymous Quiz
7%
mutableListOf()
11%
arrayListOf()
79%
listOf()
3%
mutableSetOf()
Anonymous Quiz
2%
Они могут выполняться только на основном потоке
69%
Позволяют управлять асинхронностью с минимальными затратами
7%
Запускают новый поток для каждой корутины
23%
Используют много потоков для оптимизации производительности
💊8🤯2
Да, есть три основных случая:
1. Блокирующий код – если внутри корутины используется блокирующая операция (Thread.sleep(), while(true) {}), она не реагирует на отмену.
2. Отмена родительской корутины не отменяет launch(NonCancellable) – если корутина запущена с NonCancellable, она игнорирует отмену.
3. Отмена не срабатывает, если корутина не проверяет isActive или yield() – долгие вычисления без точек приостановки не дадут корутине завершиться.
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3
Anonymous Quiz
16%
Используя индивидуальные случаи для каждого значения
63%
Группируя значения с помощью запятой
4%
Применяя регулярные выражения
17%
На каждое значение заводится отдельная ветка
Anonymous Quiz
39%
Объявив ее как private
15%
Используя internal
33%
Декларируя ее как public
12%
Никак, функции расширения всегда глобальны