А логи изменения стейта у меня вот так

Log.d(
"SET_STATE", "${reducer.javaClass.name}\n" +
_state.value.toString()
)
Тоесть я вижу какой метод и откуда вызывает изменение стейта. Вы об этом?

3 ответов

7 просмотров

Я бы добавил туда печать стека и убедился что при падении там нет вызовов из Composable-функций.

Roman-Bocharov Автор вопроса
Arkadii Ivanov
Я бы добавил туда печать стека и убедился что при ...

Вот такое вот решение придумал. получается стектрейс выведется и метод, класс и стейт

Roman-Bocharov Автор вопроса
Arkadii Ivanov
Я бы добавил туда печать стека и убедился что при ...

class ComposeShitException(override val message: String?) : Throwable(message) private val mutex: Mutex = Mutex() protected suspend fun setState(reducer: State.() -> State) { try { mutex.withLock { _state.value = state.value.reducer() Log.d( "SET_STATE", "${reducer.javaClass.name}\n" + _state.value.toString() ) } } catch (e: Exception) { ComposeShitException("${reducer.javaClass.name}\n" + _state.value.toString()).printStackTrace() e.printStackTrace() } } Вот такое решение придумал. выведется стектрейс + метод, класс который менял стейт и сами данные стейта на которые меняется

Похожие вопросы

Обсуждают сегодня

Я не понимаю, это троллинг или что? Швабрика поддерживают, который буквально пишет на ассемблере взаимодействия с винапи. Я это ещё написал загрузчик и хоть что-то изучаю в о...
Shadow Akira
6
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
Всем привет. Хотел бы написать для себя свою ос. Причины: 1) нужен опыт в чем-то 2) будет меньше весить 3) свое, но там будут свои задумки Я понимаю что нужно писать для всег...
Shadow Akira
18
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Инструкция вроде от 1 до 5 тиков ввполняется? Давайте все в ассемблер чат тему перенесём. Там будет больше людей которые связаны с этой темой. Прошу пожалуйста.
Shadow Akira
3
сколько это сотен тысяч инструкций?
Boris Vinogradov
4
Карта сайта