#AndroidDevSipummit #Conference
Android Dev Summit 2019 пройдёт 23-24 октября в Калифорнии, США. Нас ожидают доклады от инженеров из Google и анонсы.
Android Dev Summit 2019 пройдёт 23-24 октября в Калифорнии, США. Нас ожидают доклады от инженеров из Google и анонсы.
👍1
#GooglePlay #Subnoscriptions #GooglePlayBilling
Subnoscriptions 101 for Android Apps
Рассказ о серии видео Subnoscriptions 101 в которой подробно рассматриваются различные аспекты подписок в Google Play:
1️⃣ Understanding Subnoscriptions - описание терминоголоии
2️⃣ Subnoscription Purchase Flow - процесс покупки
3️⃣ Real-time Developer Notifications - возможность получения уведомлений о состоянии подписок пользователя
4️⃣ Upgrade and Downgrade - повышение/понижение подписок через Google Play Billing Library
5️⃣ Grace Period - возможность давать пользователю использовать все преимущества подписки если автоматическая оплата не прошла
6️⃣ Account Hold - возможность предоставления доступа к контенту приложения если у пользователя не прошла оплата подписки, но раньше он ей пользовался
7️⃣ Cancel and Restore - отмена и восстановление подписок
8️⃣ Defer Billing - предоставление временного бесплатного доступа (например при акциях)
Все видео в серии небольшого размера (1-3 минуты)
Subnoscriptions 101 for Android Apps
Рассказ о серии видео Subnoscriptions 101 в которой подробно рассматриваются различные аспекты подписок в Google Play:
1️⃣ Understanding Subnoscriptions - описание терминоголоии
2️⃣ Subnoscription Purchase Flow - процесс покупки
3️⃣ Real-time Developer Notifications - возможность получения уведомлений о состоянии подписок пользователя
4️⃣ Upgrade and Downgrade - повышение/понижение подписок через Google Play Billing Library
5️⃣ Grace Period - возможность давать пользователю использовать все преимущества подписки если автоматическая оплата не прошла
6️⃣ Account Hold - возможность предоставления доступа к контенту приложения если у пользователя не прошла оплата подписки, но раньше он ей пользовался
7️⃣ Cancel and Restore - отмена и восстановление подписок
8️⃣ Defer Billing - предоставление временного бесплатного доступа (например при акциях)
Все видео в серии небольшого размера (1-3 минуты)
Medium
Subnoscriptions 101 for Android Apps
Subnoscriptions on Google Play Billing can be an excellent way to grow your business. However, coordinating between your Android app and…
👍1
#Kotlin #Coroutines #Channels
Kotlin: Diving in to Coroutines and Channels
Прекрасный рассказ о разнице между работой асинхронности на основе Java Thread и Kotlin Coroutines на примере работы кофейни. В статье также рассматривается что значит "шаринг памяти через коммуникацию" на основе Channel.
Kotlin: Diving in to Coroutines and Channels
Прекрасный рассказ о разнице между работой асинхронности на основе Java Thread и Kotlin Coroutines на примере работы кофейни. В статье также рассматривается что значит "шаринг памяти через коммуникацию" на основе Channel.
Medium
Kotlin: Diving in to Coroutines and Channels
An illustrated guide to coroutines and channels in Kotlin
👍1
#Kotlin #Coroutines #Exceptions
Managing exceptions in nested coroutine scopes
Обработка исключений при выполнение вложенных корутин не так очевидна как кажется и имеет свою специфику.
Например, что будет записано в файл в результате выполнения кода?
Правильный ответ - ничего.
Причиной тому особенности Structured Concurrency. Когда происходит исключение в
оно передаётся во все родительские и дочерние корутины, которые останавливают свое выполнение, а те в свою очередь останавливают все корутины по аналогичному принципы.
Замечание: Здесь опущена возможность, что можно задать свой собственный CoroutineExceptionHandler в CoroutineContext
Есть несколько способ обойти это:
👉 При создание CoroutineScope используйте SupervisorJob, которая не останавливает дочерние корутины
👉 Для переключения CoroutineContext используйте withContext() вместо launch/async
👉 Выполняйте корутины, который бросают исключения в отдельной CoroutineScope. Создать такой scope можно с помощью функции coroutineScope()
Больше подробностей ищите в статье!
Managing exceptions in nested coroutine scopes
Обработка исключений при выполнение вложенных корутин не так очевидна как кажется и имеет свою специфику.
Например, что будет записано в файл в результате выполнения кода?
GlobalScope.launch { val text = try { async<String> { throw Exception("Test") }.await() } catch (e: Exception) { "error text" } writeToFile(text) // Suspend function}Правильный ответ - ничего.
Причиной тому особенности Structured Concurrency. Когда происходит исключение в
async то происходит следующее:оно передаётся во все родительские и дочерние корутины, которые останавливают свое выполнение, а те в свою очередь останавливают все корутины по аналогичному принципы.
Замечание: Здесь опущена возможность, что можно задать свой собственный CoroutineExceptionHandler в CoroutineContext
Есть несколько способ обойти это:
👉 При создание CoroutineScope используйте SupervisorJob, которая не останавливает дочерние корутины
👉 Для переключения CoroutineContext используйте withContext() вместо launch/async
👉 Выполняйте корутины, который бросают исключения в отдельной CoroutineScope. Создать такой scope можно с помощью функции coroutineScope()
Больше подробностей ищите в статье!
👍1
#AndroidAcademy #GDGMinsk #Architecture
Android Academy Minsk - Architecture Part 1 of 2
Сегодня, 8 апреля в 19.00, пройдет очередная лекция в рамках курса Android Academy Advanced в Минске. Вы сможете узнать о том как строить архитектуру приложения и какие подходы используют опытные разработчики.
Участие бесплатное, по предварительной регистрации. Количество мест ограничено!
Для всех тех кто не сможет попасть лекцию в течении нескольких дней будет доступна видео запись лекции на YouTube канале Android Academy Minsk.
Android Academy Minsk - Architecture Part 1 of 2
Сегодня, 8 апреля в 19.00, пройдет очередная лекция в рамках курса Android Academy Advanced в Минске. Вы сможете узнать о том как строить архитектуру приложения и какие подходы используют опытные разработчики.
Участие бесплатное, по предварительной регистрации. Количество мест ограничено!
Для всех тех кто не сможет попасть лекцию в течении нескольких дней будет доступна видео запись лекции на YouTube канале Android Academy Minsk.
👍1
How to detect if the android keyboard is open
В Android нет возможности понять показывается ли сейчас клавиатура на экране. В статье описывается лайфхак, который на основе видимой зоне на экране, и ViewTreeObserver.OnGlobalLayoutListener, добавив щепотку Lifecycle из Architecture Components, можно определять видна ли клавиатура.
Решение не без изъянов, но позволяет уже решить в проблема в самых распространенных случаях
В Android нет возможности понять показывается ли сейчас клавиатура на экране. В статье описывается лайфхак, который на основе видимой зоне на экране, и ViewTreeObserver.OnGlobalLayoutListener, добавив щепотку Lifecycle из Architecture Components, можно определять видна ли клавиатура.
Решение не без изъянов, но позволяет уже решить в проблема в самых распространенных случаях
Medium
How to detect if the android keyboard is open
You want to know, at this moment, if the android keyboard is open. Easy right? Unfortunately not.
#MVVM #Architecture #BestPractices #ArchComponents
Our Way to MVVMI and Mistakes We Made When Implementing MVVM
Лучше учиться на ошибках других. Поэтому запомните из боли разработчиков их опыт интеграции и примите следующий правила (что НЕ стоит делать) при работе с MVVM на основе Arch Components:
⛔ Передавать LiveData в качестве параметра в репозиторий и обновлять его там
⛔ Комбинировать бизнес логику и логику представления в ViewModel
⛔ Полагаться только на ViewModel для сохранения состояния между пересозданием Activity/Fragment
⛔ Не сбрасывать слушатели Repository, когда уничтожается View
⛔ Получать данные из ViewModel в View с помощь getter, а не реагировать на изменение данных через LiveData
Our Way to MVVMI and Mistakes We Made When Implementing MVVM
Лучше учиться на ошибках других. Поэтому запомните из боли разработчиков их опыт интеграции и примите следующий правила (что НЕ стоит делать) при работе с MVVM на основе Arch Components:
⛔ Передавать LiveData в качестве параметра в репозиторий и обновлять его там
⛔ Комбинировать бизнес логику и логику представления в ViewModel
⛔ Полагаться только на ViewModel для сохранения состояния между пересозданием Activity/Fragment
⛔ Не сбрасывать слушатели Repository, когда уничтожается View
⛔ Получать данные из ViewModel в View с помощь getter, а не реагировать на изменение данных через LiveData
Medium
Our Way to MVVMI and Mistakes We Made When Implementing MVVM
My story on this project started with the management’s decision of refactoring it as developers had hit the wall with “God” Activities…
👍1
#Course
Android Architecture Masterclass video course
Курс по архитектуре Android приложений, написанию чистого кода и разработке поддерживаемых приложений. Курс стоит $12.
Курс состоит из следующих частей:
1️⃣ MVx архитектурные паттерны
2️⃣ MVx в Android
3️⃣ Базисы MVC
4️⃣ Dependency Injection
5️⃣ Controller
6️⃣ Структура пакетов
7️⃣ Вложенные MVC View
8️⃣ Clean Architecture
Замечание: Насколько скидка реальна, и какое качество курса сказать не могу, но я уже его приобрел курс и потрачу 4.5 часа в ближайшие 2 недели, чтобы узнать это и расскажу вам
Android Architecture Masterclass video course
Курс по архитектуре Android приложений, написанию чистого кода и разработке поддерживаемых приложений. Курс стоит $12.
Курс состоит из следующих частей:
1️⃣ MVx архитектурные паттерны
2️⃣ MVx в Android
3️⃣ Базисы MVC
4️⃣ Dependency Injection
5️⃣ Controller
6️⃣ Структура пакетов
7️⃣ Вложенные MVC View
8️⃣ Clean Architecture
Замечание: Насколько скидка реальна, и какое качество курса сказать не могу, но я уже его приобрел курс и потрачу 4.5 часа в ближайшие 2 недели, чтобы узнать это и расскажу вам
👍1
#AndroidGradlePlugin
Google Play Instant feature plugin deprecation
В Android Gradle Plugin 3.4.0 (AGP) помечены как deprecated 2 Gradle плагина:
Для тех кто использовал одни из старых плагинов нужно мигрировать на плагин
Руководство по миграции
Google Play Instant feature plugin deprecation
В Android Gradle Plugin 3.4.0 (AGP) помечены как deprecated 2 Gradle плагина:
com.android.feature и com.android.instantapp. Изменения связаны с тем что в AGP 3.3.0 была добавлена поддержка Instant приложений в Android App Bundle.Для тех кто использовал одни из старых плагинов нужно мигрировать на плагин
com.android.dynamic-feature.Руководство по миграции
👍1
#Kotlin #Coroutines #Flows
Cold flows, hot channels
На подходе обновление kotlinx.coroutines в рамках которого добавляется поддержка Flow - "холодный" стрим данных. Flow является аналогом Sequence (синхронный блокирующий), но только асинхронным на основе корутин.
Ключевым отличием Flow является что любой вызов операции такой как
Важно: На текущий момент Flow находится в превью, это значит что возможно изменений API и совместимости на уровне байткода, также не оптимизирована производительность.
Замечание: В предыдущей версии библиотеки kotlinx.coroutines был ReceiveChannel, который представляет из себя "горячий" стрим.
Cold flows, hot channels
На подходе обновление kotlinx.coroutines в рамках которого добавляется поддержка Flow - "холодный" стрим данных. Flow является аналогом Sequence (синхронный блокирующий), но только асинхронным на основе корутин.
Ключевым отличием Flow является что любой вызов операции такой как
map(), filter() и пр. не приводит к выполнению flow. Выполнение начинается только при вызове терминальной операции, например collect.Важно: На текущий момент Flow находится в превью, это значит что возможно изменений API и совместимости на уровне байткода, также не оптимизирована производительность.
Замечание: В предыдущей версии библиотеки kotlinx.coroutines был ReceiveChannel, который представляет из себя "горячий" стрим.
👍1
#MobilePeopleTalks #Podcast
Mobile People Talks #2 - Есть ли будущее у Flutter?
Вышел второй эпизод подкаста Mobile People Talks, в котором я с товарищами устроили допрос Александру Денисову, который занимается развитием Flutter в EPAM. В рамках допроса вы узнаете:
👉 Почему Flutter заслуживает внимание?
👉 Чем кроссплатформенные инструменты отличаются от мультиплатформенных?
👉 Почему не Kotlin?
👉 Что Flutter слизал с React?
👉 Зачем вообще для Flutter понадобился Dart?
👉 Как обстоят дела с инструментарием, библиотеками и сообществом?
Допрос устроили
👉 Данис Тазетдинов, драйвер мобильного комьюнити EPAM, автор канала по iOS разработке AppleDevNews
- Кирилл Розов, Lead GDG Minsk и SchoolKt, автор канала о Android разработке Android Broadcast
- Владимир Иванов, активный спикер, член программного комитета Mobius
Google Podcasts
Apple Podcasts
Mobile People Talks #2 - Есть ли будущее у Flutter?
Вышел второй эпизод подкаста Mobile People Talks, в котором я с товарищами устроили допрос Александру Денисову, который занимается развитием Flutter в EPAM. В рамках допроса вы узнаете:
👉 Почему Flutter заслуживает внимание?
👉 Чем кроссплатформенные инструменты отличаются от мультиплатформенных?
👉 Почему не Kotlin?
👉 Что Flutter слизал с React?
👉 Зачем вообще для Flutter понадобился Dart?
👉 Как обстоят дела с инструментарием, библиотеками и сообществом?
Допрос устроили
👉 Данис Тазетдинов, драйвер мобильного комьюнити EPAM, автор канала по iOS разработке AppleDevNews
- Кирилл Розов, Lead GDG Minsk и SchoolKt, автор канала о Android разработке Android Broadcast
- Владимир Иванов, активный спикер, член программного комитета Mobius
Google Podcasts
Apple Podcasts
SoundCloud
Flutter
Mobile People Talks - есть ли будущее у Flutter?
Александр пытается рассказать про Flutter, но благодаря активному участию остальных ведущих, рассказ плавно перетекает в перекрестный допрос! Тем не
Александр пытается рассказать про Flutter, но благодаря активному участию остальных ведущих, рассказ плавно перетекает в перекрестный допрос! Тем не
👍1
#Kotlin
Вышел Kotlin 1.3.30
Вышел очередной релиз Kotlin в рамках которого были сделаны улучшения в производительности KAPT, обновления Kotlin/Native, улучшения плагина для IDE и багфикс.
KAPT
👉Поддержка инкрементального процессинга аннотаций в KAPT (экспериментально)
👉Различные улучшения производительности KAPT
Kotlin/Native
👉Улучшения логирования крешей на iOS
👉Поддержка Cocoapods (экспериментально)
👉Улучшения в C interop
👉Поддержка Kotlin/Native в IDE
Улучшения в плагине Kotlin для IntelliJ IDEA
👉 Новые возможности для дебага корутин: “Async stack trace” - позволяет просмотреть переменные в suspend точке.
👉 Теперь будут видны настоящие названия переменных из кода, а не то что генерируются компилятором
👉 Интерактивный режим в scrath файлах: на каждой строке видны результаты выполнения кода, как в debug режиме
👉 Поддержка много строчных TODO
👉 Исправление багов
👉 Улучшения в производительности
Прочее
👉 Возможность задать версию target JVM байткода от 9 до 12
👉 Добавлена поддержка платформенных Android nullability аннотаций
👉 Исправление багов
👉 Улучшения в производительности компилятора
Вышел Kotlin 1.3.30
Вышел очередной релиз Kotlin в рамках которого были сделаны улучшения в производительности KAPT, обновления Kotlin/Native, улучшения плагина для IDE и багфикс.
KAPT
👉Поддержка инкрементального процессинга аннотаций в KAPT (экспериментально)
👉Различные улучшения производительности KAPT
Kotlin/Native
👉Улучшения логирования крешей на iOS
👉Поддержка Cocoapods (экспериментально)
👉Улучшения в C interop
👉Поддержка Kotlin/Native в IDE
Улучшения в плагине Kotlin для IntelliJ IDEA
👉 Новые возможности для дебага корутин: “Async stack trace” - позволяет просмотреть переменные в suspend точке.
👉 Теперь будут видны настоящие названия переменных из кода, а не то что генерируются компилятором
👉 Интерактивный режим в scrath файлах: на каждой строке видны результаты выполнения кода, как в debug режиме
👉 Поддержка много строчных TODO
👉 Исправление багов
👉 Улучшения в производительности
Прочее
👉 Возможность задать версию target JVM байткода от 9 до 12
👉 Добавлена поддержка платформенных Android nullability аннотаций
👉 Исправление багов
👉 Улучшения в производительности компилятора
The JetBrains Blog
Kotlin 1.3.30 released | The Kotlin Blog
We’re happy to announce the release of Kotlin 1.3.30, a new bug fix and tooling update for Kotlin 1.3. The main areas of focus for this release have been around Kotlin/Native, KAPT performance, as well as improvements for IntelliJ IDEA. As always, we’d like…
👍1
#GooglePlay #Subnoscriptions #Analytics
Optimize your subnoscriptions with new insights in the Play Console
В Google Play добавили новые фичи:
👉 Аналитика подписок: конвертация из триала в платную подписку, вернувшиеся подписчики и другие метрики
👉 Просмотр результатов опроса при отмене подписок. Теперь можно понять по какой причине пользователь отменяет подписку
👉 Возможно узнать эффективность grace period (предоставления подписки со скидкой на ограниченное время) и account hold (возможность использования подписки в случае если не смогла пройти автоматическое продление) для сохранения ваших подписчиков
Optimize your subnoscriptions with new insights in the Play Console
В Google Play добавили новые фичи:
👉 Аналитика подписок: конвертация из триала в платную подписку, вернувшиеся подписчики и другие метрики
👉 Просмотр результатов опроса при отмене подписок. Теперь можно понять по какой причине пользователь отменяет подписку
👉 Возможно узнать эффективность grace period (предоставления подписки со скидкой на ограниченное время) и account hold (возможность использования подписки в случае если не смогла пройти автоматическое продление) для сохранения ваших подписчиков
Android Developers Blog
Optimize your subnoscriptions with new insights in the Play Console
Since launching on Google Play nearly 7 years ago, subnoscriptions have proven to be an essential element in creating sustainable mobile app businesses; 89 of the top 100 highest grossing apps on Google Play in the US now provide subnoscription products. As the…
#Kotlin #ktlint
Внимание всем тем кто захочет обновиться до Kotlin 1.3.30 и в вашем проекте используется KtLint, то я вас огорчу - после обновления при попытке анализа происходит ошибка. Я уже создал issue в репозитории проекта и буду ждать обновления
Внимание всем тем кто захочет обновиться до Kotlin 1.3.30 и в вашем проекте используется KtLint, то я вас огорчу - после обновления при попытке анализа происходит ошибка. Я уже создал issue в репозитории проекта и буду ждать обновления
#Kotlin #Coroutines #LibUpdates
Вышла библиотека kotlinx.coroutines 1.2.0
В обновление вы можете найти:
👉Добавлены поддержка Flow - холодных каналов. Подробности в статьи Романа Елизарова "Cold flows, hot channels"
👉 Улучшение дебага корутин
👉
👉
👉 Значительно улучшена скорость инициализации
👉 Представлен
👉 Больше не используются приватные API на последних версиях Android
👉 Добавлена invoke() функция для
👉 Kotlin 1.3.30
👉 Исправлены баги
👉 Улучшения в производительности, генерируемом коде и обработке исключений
Важное замечание: из-за обновления Kotlin в вашем проекте вам также надо его обновить + есть сейчас проблема работы KtLint с новой версией языка.
Вышла библиотека kotlinx.coroutines 1.2.0
В обновление вы можете найти:
👉Добавлены поддержка Flow - холодных каналов. Подробности в статьи Романа Елизарова "Cold flows, hot channels"
👉 Улучшение дебага корутин
👉
Dispatchers.Unconfined, MainCoroutineDispatcher.immediate, MainScope and CoroutineScope.cancel теперь стабильны👉
withContext() теперь проверяет статус активности корутины перед выполнением👉 Значительно улучшена скорость инициализации
Dispatcher.Main👉 Представлен
CompletableJob, который теперь возвращается в результате создания Job и SupervisorJob👉 Больше не используются приватные API на последних версиях Android
👉 Добавлена invoke() функция для
Dispatcher: теперь можно вместо withContext(UI) { ... } выполнять UI { ... }👉 Kotlin 1.3.30
👉 Исправлены баги
👉 Улучшения в производительности, генерируемом коде и обработке исключений
Важное замечание: из-за обновления Kotlin в вашем проекте вам также надо его обновить + есть сейчас проблема работы KtLint с новой версией языка.
👍1
#AndroidStudio #ProjectMarbel #AndroidLint
Android Studio Project Marble: Lint Performance
Project Marbel все больше раскрывает свои детали и в четвертой статье из серии рассказывается о том, как оптимизировали скорость Android Lint.
Спойлер: в Android Studio 3.3 смогли достичь сокращения времени анализа в несколько раз на некоторых проектах.
Чтоб сделать анализ работы правил более эффективным в Google разработали утилиту Android Lint Performance Probe (ALPP). ALPP позволит вам понять какие правила для вашего проекта тратят большую часть времени или съедают много оперативки.
Также не забывайте, чтобы Android Lint работал быстро, нужно соблюдать best practices. Для этого я делал перевод руководства от Tom Norbye, автора Android Lint. Кликни сюда чтобы открыть его.
Android Studio Project Marble: Lint Performance
Project Marbel все больше раскрывает свои детали и в четвертой статье из серии рассказывается о том, как оптимизировали скорость Android Lint.
Спойлер: в Android Studio 3.3 смогли достичь сокращения времени анализа в несколько раз на некоторых проектах.
Чтоб сделать анализ работы правил более эффективным в Google разработали утилиту Android Lint Performance Probe (ALPP). ALPP позволит вам понять какие правила для вашего проекта тратят большую часть времени или съедают много оперативки.
Также не забывайте, чтобы Android Lint работал быстро, нужно соблюдать best practices. Для этого я делал перевод руководства от Tom Norbye, автора Android Lint. Кликни сюда чтобы открыть его.
Medium
Android Studio Project Marble: Lint performance
Details on recent Lint performance fixes and a tool we made to pinpoint bottlenecks.
👍1
#GooglePlay #InstantApp #BestPractices
5 tips for using showInstallPrompt in your instant experience
Для всех тех кто имеет в свое портфолио Instant App разработчики из Google рассказали о практиках, которых стоит придерживаться, чтобы обеспечить наиболее комфортный переход пользователя к полной версии приложения:
👉 Используйте самую последнюю доступную версию библиотеки
👉 Если полная версия вашего приложения/игры еще не доступна - используйте раннюю регистрацию (pre-register)
👉 Запоминайте состояние вашего instant приложения для последующей его передачи в полное приложение на основе Cookie API. Таким образом пользователь сможет продолжить там где остановился.
👉 Не мешайте пользователю выполнить сценарий предложение установки полной версии приложения. Например, пользователь должен иметь сделать возможность покупки и после этого уже ему будет предложено установить в полное приложение.
👉 Сделайте явный способ установки полного приложения. Добавьте FAB "Install" или "Pre-register"
5 tips for using showInstallPrompt in your instant experience
Для всех тех кто имеет в свое портфолио Instant App разработчики из Google рассказали о практиках, которых стоит придерживаться, чтобы обеспечить наиболее комфортный переход пользователя к полной версии приложения:
👉 Используйте самую последнюю доступную версию библиотеки
play-services-instantapps👉 Если полная версия вашего приложения/игры еще не доступна - используйте раннюю регистрацию (pre-register)
👉 Запоминайте состояние вашего instant приложения для последующей его передачи в полное приложение на основе Cookie API. Таким образом пользователь сможет продолжить там где остановился.
👉 Не мешайте пользователю выполнить сценарий предложение установки полной версии приложения. Например, пользователь должен иметь сделать возможность покупки и после этого уже ему будет предложено установить в полное приложение.
👉 Сделайте явный способ установки полного приложения. Добавьте FAB "Install" или "Pre-register"
👍1
#R8 #Optimizations #JackWharton
R8 Optimization: Method Outlining
Продолжение серии статей от Jake Wharton об оптимизациях, выполняемых R8.
R8 умеет избавляться от констант, коротких методов, или методов, которые вызываются в одном месте, вставкой этого кода в место вызова. Это называется method inlining.
R8 также умеет избавляться от дублирующегося кода выделением его в новый метод и заменой оригинального кода на новый метод 🔥. Это называется method outlining.
R8 Optimization: Method Outlining
Продолжение серии статей от Jake Wharton об оптимизациях, выполняемых R8.
R8 умеет избавляться от констант, коротких методов, или методов, которые вызываются в одном месте, вставкой этого кода в место вызова. Это называется method inlining.
R8 также умеет избавляться от дублирующегося кода выделением его в новый метод и заменой оригинального кода на новый метод 🔥. Это называется method outlining.
👍1