iOS Makes Me Hate
4.07K subscribers
1.29K photos
186 videos
24 files
1.43K links
Авторский канал про iOS разработку. Путь продуктовых самураев в MAANG.

Самое больше iOS сообщество практиков: https://boosty.to/lionbond/

Автор: @lvbond Senior iOS Yandex, ex-Avito, VK
Download Telegram
🧍‍♀️ Самые полезные советы для работы с Proxyman

Одни из самых полезных инструментов для работы — это proxyman.

Раньше я сидел на Charles. НО НАСКОЛЬКО ЖЕ ПОНЯТНЫЙ, УДОБНЫЙ И БЫСТРЫЙ визуал проксимена очаровывает!

Проксимен спасение:
- когда нужно поменять множество данных с бэка
- легко тестировать скорость интернета
- ошибки и статусы ответа

Короче моя бы разработка сильно замедлилась без хороших сниферов.

В этой подборке советов решил собрать самые полезные статьи:

🔘Using Proxyman to Inspect Network Traffic. Углублённая статья-туториал: как смотреть трафик, фильтры, Map Local и др

🔘How to easily inspect and modify network traffic. Автор статей часто дает лайтовые гайды. Можно скидывать как инструкцию новичкам.

🔘How we use Proxyman. Опыт реальной команды. Кейсы, советы, как и зачем они используют Proxyman ежедневно
Please open Telegram to view this post
VIEW IN TELEGRAM
22
Как AI меняет экономику мобильных приложений

Увидел еще одну статью у моих коллег про закат кроссплатформы.

Вкратце о чем статья:
- кроссплатформа теряет преимущества. Теперь АИ тулкиты нивелирует ее сильные стороны.
- кроссплатформа может быть не нужна,
если AI уже делает разработку быстрее и дешевле даже в нативных

Как думаете, останутся ли отдельные роли или с приходом им мы станем универсалами?
10
Зачем нужен BDUI?

Дисклеймер. Стилистически не люблю BDUI за его dev exp, но вкратце обсудим его корни в посте.

Вижу многие заблуждения среди разрабов, блогеров и тп. К счастью или к сожалению, это текущая наша реальность. Никто на прямые вопросы "Как развиваться мобильщику не смотря на текущие тренды с BDUI и АИ?" кроме критики ничего не дают.

Давайте посмотрим как пришел BDUI на рынок и почему такая истерия:
1) Эту тему поднимали еще лет 10 назад, тогда были доклады и всякие статьи как люди пишут свой генератор экранчиков. Тогда такое использовали только в некоторых экранах.
2) год 2022. Те самые события. Удаления из сторов апок многих бигтехов. Как придумать план антикризиса? Вот он и был придуман. Который помогает обходить обновления экранов с бэкенда.
3) Просто поставьте себя на место манагера. Раскатка и обновления нативного кода до пользователя может доходить вместе 2 МЕСЯЦА. Когда же с BDUI — секунды, поменяв конфиг на бэке.

Еще раз. Запуск нативной фичи до юзера — 2 месяца. С BDUI — сегодня.

4) С разработанной инфрой один разраб может закатывать фичи сразу на 3-4 платформы. Я так делал и запускал соло фичи.

Минусы BDUI:
- очень дорого.
- не сделаешь сложные приложения с видео и частыми обновлениями экрана
- сложный порог входа. много незадокументированно. Не описано.
- часто много багов.

Но для манагеров это все чаще ок.

Какие приложения юзают BDUI:
- Авито. Когда я там был нативного кода я писал дай бог 5-10 реквестов в год. В 90% задачах это были огромные конфиги JSON'а
- ОЗОН. Слышал на их конфе, что у них сейчас только BDUI разрабы
- Яндекс Маркет. Там 100% инженеров пишут свой код только на BDUI
- X5. Пока инфы мало, говорят активно пилят свой фреймворк

Лично я ругаю многие BDUI технологии не потому, что мне удобен натив (iOS я правда всем сердцем люблю). А потому, что сам BDUI плохо готовят и мало кто из авторов и разрабов платформы задумывается о тех, кто юзает их технологию. Чаще это promotion driven development, где разрабы думают только о своих целях и метриках, но никто об удобстве. Но я рационально понимаю почему бизнес это хочет. И почему это надо.

Сейчас у нас тренировки по систем дизайну и мы как раз решили познакомиться ближе с этим монстром. Настолько, что сами его запроектируем и изучим изнутри.
83
Как устроена Мобильная разработка сегодня?

Посмотрел нашумевший ролик от Лехи Гладкова и не понял хейта. Да, многое звучит неприятно и местами грубо, но в этом есть правда.

Я сам начинал с кроссплатформы перед нативом. А до этого писал на php, js, go, react native. Где iOS стала моей пятой или шестой платформой. Натив в моем Тюмени был очень дорогой историей, которую еще в 2018 мало кто мог себе позволить. Более того, были директора кто ненавидел американский айфон всей душой и считал их любителей — позерами.

Может быть, именно это сопротивление в начале пути заставляет держать фокус в канале на нативе. От Hate до Love — one step.

Потому что бизнесу всегда это было интересно. Бизнес не ищет "самый правильный" путь — он ищет самый выгодный.

Поэтому я не понимаю хейта критиков, что PWA, кроссплатформа и BDUI — не интересны бизнесу. Они всегда были интересны. Всегда я спорил и отстаивал на цифрах и метриках что натив нужен. Отрицать привлекательность более дешевых технологий === наивно.

У кроссплатформы есть серьезные минусы из-за которых многие компании свернули отделы:
- сложность поиска сцепов. В нативе чаще проще найти чела, кто гораздо лучше проходит стандартные собесы и не требует миллиарды.
- нет компромиссов и много костылей
- BDUI с нативными компонентами — самый дешевый и лучший аналог любой кроссплатформы

Когда же нужен натив? В красивых апках, со сложной анимацией, большим кол-вом триггеров из сети. Тот же телеграм или чат не сделаешь нормально на кроссплатформе со стабильными 60 фпс.

Именно поэтому я делаю канал еще и про прокачку системного, алгоритмического и продуктового мышления, чтобы разработчик мог думать шире.

Времена сложные. Санкции. Экономика. О каком эстетизме и удобстве идет речь, когда банально у многих компаний стоит цель выжить?

Натив — это круто и здорово, но тут нужно убрать фанатизм, чтобы не было больно.

Нужно много раз задуматься чтобы идти вкатываться в иос разработку, где уже целый год вакансий не стало х2. Уже не станешь только разрабом одной платформы. Это лакшери история, которую нужно ценить и развивать.
9
Яндекс меняет процесс найма

В авито я был в инициативной группе тех, кто помогал улучшить собесы. Лично я старался обновить и дополнить алгоритмическую секцию и платформенную iOS. Да и в целом активно собесил и в общем провел около 100 секций. Может быть кто-то даже попал на мои собесы.

Здесь есть много вопросов, которые нужно держать в голове: метрики time-to-hire и time-to-offer, чтобы сложные собесы не затянулись на месяцы. Ротацию задач. Их адекватность и реальную пользу. Мы проводили опросы среди других интервьюеров, ходили к нанимающим менеджерам, меняли задачи, улучшали процесс. Старались чтобы каждый был справедливо оценен нами и нанимающими манагерами.

В крупных компаниях, где в день по 100 собесов, это очень важно. Из 100 человек доходит до финала обычно только 20. А доходят они бывает только спустя 30-40 дней с момента контакта с hr. Вот и яндекс решил актуализировать свой процесс

Нет, алгосекции не убрали. Но добавили новый этап — оценка опыта

Секция про опыт позволяет провалидировать навыки техлида, которые сложно проверить только кодовой или архитектурной задачкой.


Подробнее о ней писал CTO Лавки

Тип секций Bar raising помогает повысить объективность оценивания и скомпенсировать неопытность некоторых интервьюверов. Где-то можно снизить вес очевидно случайно проваленной секции (дали слишком лютую задачку, или она просто не зашла, хотя по прочим секциям скилл виден), а где-то, наоборот, не допустить откровенно компромиссный найм (при наличии ред-флагов, которые бар-рейзер видит с высоты своего опыта, или если все секции пройдены прям "на тоненького").


UPD: для мобил нет блока с опытом
115
BDUI vs WebView

В комментах прошлого поста спросили: "Зачем нужен BDUI, если есть WebView?".

И это один из хороших вопросов.

Я встречал приложения, которые были написаны на WebView бэкендерами, а потом переписывались на натив. Основные причины:

1️⃣ Нативный опыт

WebView — это минибраузер со своим движком. Он обрезан и еще выглядит плохо. Можно конечно вложиться, чтобы UI выглядил достойно, но чаще это эквилибристика между скиллом и дизайном.

Но тот же скролл в WebView выглядит неестественно. А JS задержки создают доп проблемы. Импут лаг натива намного красивее.

На слабых устройствах перфоманс сложного лайаута WebView упадет на дно.

По сути BDUI это тот же браузер, но который управляет нативной версткой.

2️⃣ Безопасность.

В целом всякие переходы в вебвью и инъекции — это доп геморой. В нем намного легче украсть токены, данные, подменить интерфейс и код. Можно конечно заморочиться с доп сертификатами и защитой, но это сложно, неудобно и дорого.

А с нормальными логами можно попрощаться.

3️⃣ Глубокая интеграция с приложением

Прямой доступ ко всем функциям в BDUI (ведь это тот же натив).

В вебвью очень сложно работать с:
- доступностью
- платформенными анимациями
- навигацией
- кастомными пушами
- системными жестами
- темы и кастомизация
- использовать нативные стэки
- работать с датчиками устройства

И многое другое. Это основные причины, почему уже +- зрелое приложение уходит от WebView или PWA.

На скриншоте схема MVP BDUI, которую мы рисовали на тренировках по систем дизайну. Рисовал ее я. Меня внезапно собесили.
112
Forwarded from The Экономист
Российских студентов начали обучать программированию на кириллице. В Пензенском госуниверситете преподаватели адаптировали JavaScript, полностью переведя синтаксис и задания на русский язык. По словам разработчиков, проект призван уменьшить зависимость от англоязычных стандартов.

🤑 The Экономист
Please open Telegram to view this post
VIEW IN TELEGRAM
32
Mobile System Design

Сегодня у меня день рождения и мы набрали 100 лайков.

Этот канал всегда был моим проектом для души. Я никогда не покупал рекламу. Не просился на коллабы. Не накручивал лайки, подписчиков, опыт и заслуги. Мне всегда важна органика.

Искренность. Мне важна чистота и правдивость метрик для деббага.

Я начинал писать статьи на хабре и так все закрутилось, что вырос этот канал. Теперь стараюсь и читателей благодаратить контентом.

Написал статью про систем дизайн. Можете почитать на выходных.
141106
Как писать юнит-тесты на многопоточный код

Следующий месяц будет преимущественно про Advanced Swift Concurrency + Swift 6:
🔘Порешаем самые интересные задачи
🔘изучим не только плюсы, но и глубже познакомимся с проблемами
🔘сразу перейдем к практике и задачам
🔘и многое другое

Начнем со статьи с интересной темой — написание юнит тестов с многопточным кодом. Почему это важно:
- меня пару раз просили на собесах писать тест именно на многопоточный код. И не всегда оптимальное решение приходит сразу в голову
- не все пишут такие тесты в реальных проектах из-за страха флаки тестов, хотя писать их супер важно.
Please open Telegram to view this post
VIEW IN TELEGRAM
8
📥 RuStore может появиться на iPhone

В тестовой версии нашли функцию RuStore Bridge, которая позволит устанавливать приложения из RuStore на iPhone через подключение к Android-смартфону по USB.
249
На каком стэке преимущественно (>60% кода за последний месяц) вы пишите текущий проект?
Anonymous Poll
31%
UIKit + GCD
25%
UIKit + Swift Councurrency
33%
SwiftUI + Swift Councurrency
5%
SwiftUI + GCD
14%
SwiftUI + Combine
6%
Кроссплатформа
7%
BDUI
8%
UIKit + Combine
8%
Другое
A deep dive into Collections, Sequences, and Iterators in Swift

Походу Donny Wals читает наш канал, хоть и с опозданием. Ведь еще в феврале была серия постов как мы писали свою потокобезопасную коллекцию тут, тут и тут

Донни считает что знать это полезно потому что:
- Понимание Sequence и Collection помогает писать структуры или расширять существующие с правильной семантикой
- Знание как работет под капотом for in помогает предвидеть проблемы с производительностью или безопасностью

Когда я работал в Авито Финтехе, то это помогло мне в задаче из практики: тогда мне нужно было сделать историю операций. Ну как в банках где показано куда и когда вы что-то получали и оплачивали.

Нужно было пагинировано загружать блоки. Обычный массив мне показалось скучно. Да и планов на этот экран было много: обновлять через вебсокеты и делать это интерактивно. Выгружать данные из CSV. Добавлять сложные запросы. Подписки, баланс, статусы перевод. Короче, хз че как там сейчас. Но экран был потенциально амбициозный (а как еще эффективно продать разработку разрабам).

Я решил запроектировать и написать свою коллекцию TransactionsHistory, а для универсальных транзакций заюзать какой-нибудь WalletActivityStream (AsyncSequence).

Почему не подходил обычный массив?
- Ну, массиву нужно знать заранее сколько памяти хранить. Это не всегда эффективно по памяти.
- Копируется при мутации (CoW). Мутации требуют перераспределения данных
- Большие массивы === большой риск Out Of Memory
- Нет асинхронной семантики
- Нет ленивой выборки

Если у пользователя 20 000 транзакций — в память загружается весь буфер. Если пришла новая операция, то массив нужно пересоздавать или вставлять, а это потенциально капец как дорого. Статус платежа изменился? Снова изменение коллекции. Ну и вот такие детали помогают лучше понимать когда нужна коллекция, а когда стрим.

Так сделал ли я в итоге крутую коллекцию? Отложил после MVP 😂
Please open Telegram to view this post
VIEW IN TELEGRAM
12
📺 Swift Concurrency + Swift 6 на практике

Мы снова глубоко погружаемся в Swift Concurrency. На канале было много теории и практики — но этого все равно мало.

Хочется услышать опыт инженера, который прошел этот путь в проде: переписывал и лидировал проекты, сталкивался с подводными камнями и точно знает, что работает, а что нет.

👨‍🦱 Наш ДОРОГОЙ друг Савва @ios_iss_blog — ведущий инженер, который уже перевел несколько крупных приложений на Swift Concurrency и Swift 6. В своем канале он подробно делится разными кейсами.

В выпуске он поделился:
🟣с какими неожиданностями пришлось столкнуться
🟣насколько документация помогает в реальных задачах
🟣что изменилось в правилах языка и почему об этом важно знать
🟣практическими советами и лайфхаками для разработки

Этого не расскажет чатгпт!

🧑 Сейчас — идеальный момент, чтобы переходить на современный стек. Если вы собираетесь обновить старый проект или хотите лучше понимать новую эволюцию языка, этот выпуск будет максимально полезен.

В конце месяца сделаем тренировки по SC и порешаем реальные задачи.

Получить доступ по скидке 💰тут или ⭐️ тут
Please open Telegram to view this post
VIEW IN TELEGRAM
1342
The price of mandatory code reviews

Холливара перед выходными.

Код ревью переоценено. Во многих компаниях в этот процесс вкладывают больше, чем он может дать. Иногда ошибочно считая что только детальное и дотошное ревью помогает обеспечить наивысшее качество проекта. А еще хуже когда внедряют метрику "сколько ты сделал комментариев реквестам". Так некоторые эксперты искусственно создают свою значимость и отказываются от движения вперед.

Для меня код ревью теряет ценность и становится каким-то около формально-бюрократичным процессом во многих компаниях. Я выделяю несколько причин:
- слишком большой поток реквестов и ревьюеров размывает ответственность и не дает нормально вчитываться
- сложные и большие реквесты даже если ревьюится, то уже поздно на что-то глобально влиять. Код написан. Ты не можешь развернуть разраба и приходится идти на компромиссы. Тут лучше справляется арх ревью, а не код ревью
- в крутых командах высокое доверие. Если тебе нужно выделять час времени и писать 30-40 комментов своему коллеги, то проблема сидит глубже.
- в больших компаниях и командах кодревью почти условное из-за огромного кол-ва велосипедов, BDUI, кроссплатформ и тп. У тебя не хватает экспертов кто также хорошо разбирается в том, в чем разбираешься ты

Вот и автор приводит данные: сравнение команд, где код-ревью обязательны, и тех, где их нет или они используются по желанию.
- Команды без обязательных ревью работают быстрее, но выпускают больше багов
- Команды с обязательными ревью имеют меньше багов, но могут быть медленнее

Вывод автора: обязательные ревью — не универсальное решение. Он предлагает: пусть ревью будут выборочными, качественными и быстрыми.

Кодревью нужно, но оно не должно быть только одним процессом качества. Гораздо лучше помогают:
- автотесты при разработке
- архревью перед разработкой больших задач
- аи тулкиты могут снизить рутину и уже неплохо подсвечивают критические и грубые ошибки
- парное программирование
8
Servant Leadership

Не все идеи agile и scrum я поддерживаю. Но некоторые очень нравятся. Например идея о сервант-лидерстве. Есть в ней что-то самурайское.

Сервант-лидерство = “служить, чтобы вести”: лидер ставит успех людей выше личных заслуг, действует с позиции скромности и не "забирает" себе победы команды. Ключевые принципы: доверие, эмпатия, сотрудничество и этичное использование влияния; лидер «ведёт из-за спины», убирая препятствия и помогая самоорганизации.

Это стиль для лидеров в команде — фокус на создании условий, в которых команда сама принимает решения и растёт.


Почему-то в современном мире любая мысль "думать о других, а не о себе" высмеивается и считается куколдизмом. Мне это сложно понять и я считаю это незрелой позицией. Особенно когда многие результаты можно добиться только командной игрой, где важно доверие и поддержка.
166
DivKit

Почти каждый яндексоид знает что это за зверь. Да что там яндексоид, я до яндекса слышал о нем разное... Среди каналов и разрабов, кто не работал с BDUI, есть много мифов и заблуждений.

Будто App Store может тебя заблокировать из-за этого или что BDUI развитие только в СНГ (где удаляют прилы). Но почти все фаанг компании написали и юзают по паре таких технологий. Тот же Facebook*(осуждаем и порицаем) и апки гугла почти все на BDUI.

А в СНГ это Авито, Озон, Х5, Маркет.

DivKit — это фреймворка для BDUI. Это позволяет менять экран без релиза приложения и переиспользовать код и настройки UI между платформами. Под капотом — общий JSON, набор рендереров для клиентов и утилиты для генерации/сборки JSON на сервере.


На тренировках по систем дизайну мы разбирали BDUI. Где я во многом опирался на общие практики.

Как это работает:
- Сервер формирует JSON (карточку/экран) — руками или через json-builder.
- Клиент получает JSON и отдаёт его див-рендереру (DivView), который строит нативную иерархию.
- Интерактивность описывается в JSON: состояния, анимации переходов, обработчики действий, переменные.

Самое важное что пишется в самой доке это рекомендации когда юзать DivKit, а когда нет. На мой взгляд это отличный чеклист для всех BDUI:
- Нужно часто менять интерфейс без публикации в сторах
- Хочется единый контракт на UI между iOS/Android/Web

Когда не нужно использовать:
- Экран редко меняется, а весь продукт — чисто нативный без SDUI-процессов
- Команда/процессы не готовы поддерживать контракты и версии между клиентом и сервером
- Когда нужны сложные анимации и красивый UI

Ставь 🖤 если нравится BDUI
и 💀 если нет
Please open Telegram to view this post
VIEW IN TELEGRAM
75942
TaskLocal в Swift

В нашем воркшопе по Swift Concurrency + Swift 6 Савва немного прошелся по TaskLocal. Подметив, что это интересная, но редкая механика языка. Я даже пошел копаться в последних проектах и не нашел ни одного использования.

Представь, что у тебя куча асинхронных задач. Каждой нужен свой контекст — ID запроса, логгер, настройки. Как решать эту задачу?

Пробрасывать через параметры? Замусорено при большом кол-ве.
Глобальная переменная? Гонка данных. TaskLocal — элегантное решение.

Данные доступны везде внутри этой задачи и ее детей, но не видны другим задачам.

Ситуация: Пользователь делает запрос к серверу. Ты хочешь логировать всё, что происходит с этим запросом — куда ходили, что упало, сколько времени заняло.

🧬 Без TaskLocal: контекст либо глобальный, либо прокидываешь через 100500 параметров.

💎 С TaskLocal: каждая задача живет в своем контексте с данными, которые видны всем внутри, но изолированы от других задач.

Это как номер заказа в ресторане — официант не таскает бумажку с номером, но всегда знает, какой заказ обслуживает. Другие официанты со своими заказами ему не мешают.
Please open Telegram to view this post
VIEW IN TELEGRAM
13