Работа с таймером в AlarmKit
Одним из фреймворков, представленных на WWDC, стал AlarmKit.
Для интеграции необходимо выполнить всего пару простых шагов (и добавить ключ
📖 В этом туториале можно посмотреть на пример настройки проекта вместе с Live Activity (для локскрина и Dynamic Island) и познакомиться с возможностям конфигурации.
😃 iOS Dev
Одним из фреймворков, представленных на WWDC, стал AlarmKit.
Для интеграции необходимо выполнить всего пару простых шагов (и добавить ключ
NSAlarmKitUsageDescription
).📖 В этом туториале можно посмотреть на пример настройки проекта вместе с Live Activity (для локскрина и Dynamic Island) и познакомиться с возможностям конфигурации.
Please open Telegram to view this post
VIEW IN TELEGRAM
5 13👍7🔥7❤🔥2✍1💯1
Сколько iOS-разработчиков в вашей команде?
Anonymous Poll
24%
1
15%
2
11%
3
18%
4-5
12%
6-10
7%
11-20
3%
21-30
10%
> 30
🔥13✍11❤🔥4 3⚡2💯2 2👍1
Кто такой senior-разработчик
Тот, кто проработал больше 5 (10) лет? Тот, кто лучше всех знает, как устроен компилятор? Человек, который лучше всех пишет код?
А что вообще значит «лучше»?
Моя позиция, что совершенно необязательно человек должен знать всё обо всём, чтобы считаться таковым. В целом, все эти лычки/звания относительны и меняются от одной компании к другой (а иногда и от отдела к отделу). Более того, даже на стадии собесов проверяющие могут сделать вывод, кардинально отличающийся от другого набора собеседующих в той же компании.
На мой взгляд, ни количество кода, ни тем более количество задач (которые некоторые менеджеры считают объективным показателем), не отражают уровень владения инструментами.
При этом, даже на отдельно взятой задаче среднего уровня - вполне можно оценить уровень погружения в контекст. Намного важнее корреляция количества задаваемых вопросов к граничным условиям самой задачи, и что намного более важно — ресурсов на поддержку кода в будущем (здесь можно оценить количество потенциальных багов, их вариации и вектор возможных проблем).
То, что называют системным дизайном (или проектированием, терминология не так важна) вполне может проецироваться не только на глобальный уровень при создании приложения, но и на его компоненты. Масштабирование, способность реагирования на ошибки (или отказы) и вместе с тем сохранение производительности — важные вехи при реализации.
Мне импонирует сравнение на счёт количества строк в коде (что джун добавляет 50 строчек, миддл 1000, а сеньор удаляет 5), это не так далеко от правды. Премировать за количество строк кода — нонсенс, но я слышал и такие истории. Конечно, в случае если вы Маяковский - это можно оправдать, но в остальных ситуациях это просто за гранью разумного.
Способность писать понятный другим код (и вам, если вернетесь к нему через три года) — навык, который вырабатывается итерационно, иногда годами. В этом плюс ревью в команде (залетайте в тред, возможно вам будет что добавить).
Поэтому сениор это не только человек, который способен решить задачу по заданному тз (хотя это буквально то, что требуется), но и профессионал, ход мыслей которого можно понять просто посмотрев на решение.
И хотя это может показаться очевидным, на самом деле дистанция от «решил» до «решил понятно» может быть гигантской.
А умение формулировать свои мысли — важно не только в разработке, но и в жизни.
А кто в вашем понимании сениор-разработчик? Поделитесь мнением.
😃 iOS Dev
Тот, кто проработал больше 5 (10) лет? Тот, кто лучше всех знает, как устроен компилятор? Человек, который лучше всех пишет код?
А что вообще значит «лучше»?
Моя позиция, что совершенно необязательно человек должен знать всё обо всём, чтобы считаться таковым. В целом, все эти лычки/звания относительны и меняются от одной компании к другой (а иногда и от отдела к отделу). Более того, даже на стадии собесов проверяющие могут сделать вывод, кардинально отличающийся от другого набора собеседующих в той же компании.
На мой взгляд, ни количество кода, ни тем более количество задач (которые некоторые менеджеры считают объективным показателем), не отражают уровень владения инструментами.
При этом, даже на отдельно взятой задаче среднего уровня - вполне можно оценить уровень погружения в контекст. Намного важнее корреляция количества задаваемых вопросов к граничным условиям самой задачи, и что намного более важно — ресурсов на поддержку кода в будущем (здесь можно оценить количество потенциальных багов, их вариации и вектор возможных проблем).
То, что называют системным дизайном (или проектированием, терминология не так важна) вполне может проецироваться не только на глобальный уровень при создании приложения, но и на его компоненты. Масштабирование, способность реагирования на ошибки (или отказы) и вместе с тем сохранение производительности — важные вехи при реализации.
Мне импонирует сравнение на счёт количества строк в коде (что джун добавляет 50 строчек, миддл 1000, а сеньор удаляет 5), это не так далеко от правды. Премировать за количество строк кода — нонсенс, но я слышал и такие истории. Конечно, в случае если вы Маяковский - это можно оправдать, но в остальных ситуациях это просто за гранью разумного.
Способность писать понятный другим код (и вам, если вернетесь к нему через три года) — навык, который вырабатывается итерационно, иногда годами. В этом плюс ревью в команде (залетайте в тред, возможно вам будет что добавить).
Поэтому сениор это не только человек, который способен решить задачу по заданному тз (хотя это буквально то, что требуется), но и профессионал, ход мыслей которого можно понять просто посмотрев на решение.
И хотя это может показаться очевидным, на самом деле дистанция от «решил» до «решил понятно» может быть гигантской.
А умение формулировать свои мысли — важно не только в разработке, но и в жизни.
А кто в вашем понимании сениор-разработчик? Поделитесь мнением.
Please open Telegram to view this post
VIEW IN TELEGRAM
8 30👍14❤🔥11🔥6✍2👏1
Типобезопасная и удобная обработка ошибок в Swift 6
Swift 6 привнес в язык новую интересную возможность: typed throws. С помощью этого изменения можно определить, какие типы ошибок может выбрасывать функция.
На первый взгляд это небольшое изменение, но на самом деле открывает путь к написанию более чистого и надежного кода.
📖 В этом посте можно посмотреть на пример кастомного протокола ошибок и на два кейса использования в Swift 6.
😃 iOS Dev
Swift 6 привнес в язык новую интересную возможность: typed throws. С помощью этого изменения можно определить, какие типы ошибок может выбрасывать функция.
На первый взгляд это небольшое изменение, но на самом деле открывает путь к написанию более чистого и надежного кода.
📖 В этом посте можно посмотреть на пример кастомного протокола ошибок и на два кейса использования в Swift 6.
Please open Telegram to view this post
VIEW IN TELEGRAM
7🔥19👍11 8✍3
Reaper — фреймворк для обнаружения неиспользуемого кода в рантайме
В качестве примера разработчики приводят историю уменьшения кодовой базы Duolingo на целый процент (или 10 000 строк кода).
Он поддерживает все классы, написанные на Objective-C, большинство non-generic классов Swift и некоторые structs/enums Swift.
Инструмент от Emerge tools (теперь он опенсорс как и FaultOrdering) определяет набор используемых классов, а каталог Scripts в этом репозитории содержит программу для определения набора всех возможных типов, которые может обнаружить reaper. Разница между этими наборами - неиспользуемые типы.
➡️ О влиянии фреймворка на перфоманс можно почитать здесь, а к бинарнику это добавит <20 килобайт.
📖 Статья с примерами и разбором для iOS (и Android) доступна вот тут.
😃 iOS Dev
В качестве примера разработчики приводят историю уменьшения кодовой базы Duolingo на целый процент (или 10 000 строк кода).
Он поддерживает все классы, написанные на Objective-C, большинство non-generic классов Swift и некоторые structs/enums Swift.
Инструмент от Emerge tools (теперь он опенсорс как и FaultOrdering) определяет набор используемых классов, а каталог Scripts в этом репозитории содержит программу для определения набора всех возможных типов, которые может обнаружить reaper. Разница между этими наборами - неиспользуемые типы.
📖 Статья с примерами и разбором для iOS (и Android) доступна вот тут.
Please open Telegram to view this post
VIEW IN TELEGRAM
8 17🔥11👍8✍4❤🔥2⚡1🏆1