Оптимизация времени запуска мобильного приложения (Warm Start)

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Оптимизация времени запуска мобильного приложения (Warm Start)
Сложная
~2-3 рабочих дня
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1052
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    862
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Оптимизация времени запуска мобильного приложения (Warm Start)

Warm start — приложение уже было запущено, процесс жив в памяти, но Activity/ViewController пересоздаётся. На Android это типичная ситуация после свайпа из Recent Apps и повторного открытия, или после того как система убила Activity из-за нехватки памяти, оставив процесс. На iOS — возврат в приложение после длительного пребывания в фоне, когда ViewController был выгружен из памяти.

Warm start медленнее hot start (когда процесс и Activity живы), но быстрее cold start — JVM/Dart VM/JS runtime уже запущены, Application-код уже выполнен. Проблема в том, что восстановление состояния при warm start часто делается неправильно.

Android: SavedInstanceState и ViewModel

Главная ловушка warm start на Android — неправильная обработка SavedInstanceState. При уничтожении Activity система вызывает onSaveInstanceState, разработчик сохраняет данные, Activity пересоздаётся с savedInstanceState != null. Всё хорошо — пока в Bundle не попадают большие объекты.

Bundle не предназначен для сериализации больших данных. 500KB изображений в Bitmap, сериализованный список из 200 объектов — это TransactionTooLargeException в лучшем случае, в худшем — тихий crash. Правило: в Bundle — только ID, minimal state. Данные — в ViewModel, которая переживает пересоздание Activity.

ViewModel с SavedStateHandle — правильный подход: SavedStateHandle хранит только ID/примитивы в Bundle, полные данные хранятся в ViewModel.stateFlow, восстанавливаются из репозитория по ID при необходимости.

Тяжёлые операции в onCreate при warm start — классическая ошибка. Разработчик пишет код для cold start, забывая что при warm start onCreate вызывается снова. Инициализация Room, создание Retrofit-клиента, запуск WorkManager — всё это не должно повторяться при каждом onCreate. Dagger/Hilt @Singleton решает проблему для инфраструктурных компонентов, но за логикой инициализации нужно следить.

iOS: жизненный цикл и State Restoration

На iOS warm start происходит при возврате в приложение после того, как ViewController был выгружен из-за didReceiveMemoryWarning. viewDidLoad вызывается снова, viewWillAppear тоже. Проблема — если вся логика инициализации экрана в viewDidLoad, она выполнится повторно: сделает лишние сетевые запросы, пересоздаст UI, потеряет позицию скролла.

UIKit State Restoration API (encodeRestorableState, decodeRestorableState) — правильный механизм, но используется редко из-за сложности. Чаще встречается ручной подход: сохранение состояния в UserDefaults или через Codable в файл.

SwiftUI лучше справляется с этой проблемой через @StateObject и @AppStorage — state автоматически переживает пересоздание View. Но при использовании UIKit-хостинга (UIHostingController) нужно следить за тем, чтобы не пересоздавать @StateObject при каждом обёртывании.

Главная статья потерь на iOS при warm start — повторные сетевые запросы данных, которые уже были загружены до выгрузки. Правильный слой кэширования в репозитории (NSCache для in-memory, CoreData/Realm для persistence) позволяет мгновенно показать данные из кэша и обновить в фоне.

Практический кейс

Приложение e-commerce с каталогом товаров. Warm start на mid-range Android занимал 1.8 секунды. Profiler показал: 900ms — пересоздание Retrofit/OkHttp клиентов в Fragment.onCreateView, 400ms — синхронный запрос к Room для загрузки категорий, 500ms — inflate сложного RecyclerView layout.

Исправления: Retrofit в @Singleton через Hilt, Room-запрос перенесён в ViewModel.init с viewModelScope.launch, категории закэшированы в memory с TTL 5 минут, layout упрощён с ViewBinding precompile. Итог: warm start 0.4 секунды.

Метрики и инструменты

Android: adb shell am start -W package/activity — показывает TotalTime для warm start. Для детального анализа — Perfetto с секцией ActivityThread.handleStartActivity. Firebase Performance Monitoring автоматически трекает startup traces в продакшене.

iOS: Instruments → Time Profiler с App Launch шаблоном. MetricKit в iOS 13+ собирает MXAppLaunchMetric с разбивкой на cold/warm/resume.

Срок оптимизации — одна-две недели в зависимости от количества экранов и сложности архитектуры.