Нативная разработка iOS-приложения на Objective-C

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

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Нативная разработка iOS-приложения на Objective-C
Сложная
от 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

Нативная разработка iOS-приложения на Objective-C

Objective-C — не legacy в смысле «устарело и не работает». Это production-ready язык с полной поддержкой Apple SDK, который до сих пор компилируется в те же бинарники, что и Swift. Разница в том, что новые API Apple выходят с Swift-first аннотациями, а некоторые concurrency-фичи недоступны. Для поддержки существующих ObjC-кодовых баз или особых требований заказчика — это полностью рабочий путь.

Когда это актуально

Основной сценарий: крупная кодовая база на Objective-C, которую нецелесообразно полностью мигрировать. Добавление нового функционала на ObjC поддерживает единообразие, снижает риск ошибок на Swift/ObjC boundary и упрощает ревью для команды.

Второй сценарий: C/C++ интеграция. Objective-C++ (.mm файлы) позволяет напрямую смешивать C++ и ObjC код — это востребовано в embedded, audio, game-движках, где core library написана на C++. Swift вызывает C++ через bridging header, но это сложнее и менее прозрачно.

Архитектура и паттерны

MVC — стандарт UIKit, но в ObjC он особенно склонен превращаться в Massive View Controller. Делегируем логику в отдельные классы: NSObject-наследники как service layer, NSOperation / NSOperationQueue для управляемой конкурентности, NSNotificationCenter для слабосвязанных событий.

Паттерны управления памятью: ARC закрывает большинство кейсов, но __weak и __unsafe_unretained требуют аккуратности в delegate-паттернах и block-каллбеках. retain cycle в ObjC block — self захватывается неявно, нужен __weak typeof(self) weakSelf = self + __strong typeof(weakSelf) strongSelf = weakSelf внутри блока.

Сетевой слой: NSURLSession с completion handlers или Alamofire (который прекрасно работает из ObjC через bridging). JSON-парсинг: NSJSONSerialization нативно или Mantle для model mapping.

Типичные проблемы в ObjC-проектах

EXC_BAD_ACCESS на nil-dereference происходит реже из-за того, что сообщение nil в ObjC возвращает 0/nil вместо краша — но это же маскирует логические ошибки. NSZombies (Edit Scheme → Diagnostics → Enable Zombie Objects) помогает ловить обращения к освобождённым объектам в Debug-сборках.

Category collision: два разных pod'а добавляют категорию на NSString с одинаковым именем метода — undefined behavior. Проявляется как случайный краш или неожиданное поведение. Решение: namespace-префиксы методов категорий (my_trimmed вместо trimmed).

Xcode 15 выдаёт предупреждения на ObjC код, который не был помечен NS_SWIFT_UNAVAILABLE — это не ошибки, но стоит их разобрать.

Процесс

Аналогичен Swift-разработке: Clean Architecture адаптируется под ObjC без потерь. Unit-тестирование через XCTest работает идентично. Fastlane для CI/CD — без изменений. Firebase Crashlytics, Amplitude, Segment — все подключаются через CocoaPods с ObjC-совместимыми API.

Сроки и стоимость — аналогичны Swift-разработке сопоставимого масштаба. Простое приложение: 3–4 недели. Сложное с интеграциями: 2–3 месяца. Расчёт индивидуален после анализа ТЗ.