Using Observations to observe @Observable model properties
🆕 С
🔍 Объект
❗️ Важно использовать
⚠️ При использовании Observations можно пропустить значения, если они производятся быстрее, чем вы их обрабатываете, поэтому рекомендуется реализовать собственное буферизование.
➡️ Новая система
Xcode 26 и Swift 6.2 появилась возможность использовать объект Observations для наблюдения за свойствами моделей @Observable, что упрощает процесс наблюдения вне SwiftUI.Observations позволяет создать AsyncSequence, который будет эмитировать значения при изменении наблюдаемых свойств, таких как count в модели Counter.[weak self] в замыкании Observations, чтобы избежать циклов удержания, что может привести к утечкам памяти.Observations предлагает did set semantics, в отличие от withObservationTracking, который использует will set semantics, что улучшает реакцию на изменения.@Observable
class Counter {
var count: Int
}
class CounterObserver {
let counter: Counter
init(counter: Counter) {
self.counter = counter
}
func observe() {
Task { [weak self] in
let values = Observations { [weak self] in
guard let self else { return 0 }
return self.counter.count
}
for await value in values {
guard let self else { break }
print("counter.count: \(value)")
}
}
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥4
Detecting Text Language with NLLanguageRecognizer in Swift
ℹ️ Для определения доминирующего языка текста используется структура
❓
⚙️ Можно добавить возможность возвращать оценки уверенности в предсказании языка и использовать языковые подсказки для повышения точности распознавания в многоязычных приложениях.
✔️
LanguageDetector, которая инициализирует NLLanguageRecognizer, обрабатывает строку и возвращает код языка в формате ISO 639-1.NLLanguageRecognizer использует статистические модели, обученные на больших текстовых корпусах, и лучше всего работает с полными предложениями или абзацами, а не с короткими фразами.NLLanguageRecognizer — это мощный API, который позволяет интегрировать определение языка в приложение без необходимости в серверных вызовах и задержках.import NaturalLanguage
struct LanguageDetector {
static func languageCode(for text: String) -> String? {
let recognizer = NLLanguageRecognizer()
recognizer.processString(text)
if let language = recognizer.dominantLanguage {
return language.rawValue // "en", "ru", "de", etc.
}
return nil
}
}
static func detectLanguage(for text: String) -> (code: String, confidence: Double)? {
let recognizer = NLLanguageRecognizer()
recognizer.processString(text)
guard let language = recognizer.dominantLanguage else { return nil }
let hypotheses = recognizer.languageHypotheses(withMaximum: 1)
let confidence = hypotheses[language] ?? 0
return (language.rawValue, confidence)
}
Please open Telegram to view this post
VIEW IN TELEGRAM
⚡3
Сам себе Шерлок: 7 способов найти логи и поймать баг на iOS
Очередная база - лонгрид про логи⚙️
🖥 Статья описывает 7 проверенных способов сбора логов на iOS, включая использование .ips файлов,
❓ Логи делятся на креш-отчёты, диагностические и аналитические данные, которые помогают выявить причины сбоев и проблем с производительностью приложения.
❓ Для работы с логами могут потребоваться инструменты, такие как
👀 Логи помогают разработчикам и тестировщикам убедиться в вызове функций, отслеживать сетевые запросы и выявлять ошибки, которые не отображаются на UI.
⚠️ Рекомендуется собирать логи сразу после инцидента, так как старые .ips файлы автоматически удаляются системой.
Очередная база - лонгрид про логи
log collect CLI, Xcode и утилиты Console.Xcode, libimobiledevice и Apple Configurator, а также доступ к устройству по проводу или Wi-Fi.Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3👍1
Testing Private Members in Swift with @_private(sourceFile:)
👀 Атрибут
❓ Ранее разработчики могли либо делать приватные члены внутренними, что нарушает инкапсуляцию, либо тестировать только через публичные API, что усложняет отладку.
⚙️ Для использования
⚠️ Рекомендуется использовать
@_private(sourceFile:) в Swift позволяет тестировать приватные члены классов, обходя контроль доступа, что полезно для написания более точных юнит-тестов.@_private необходимо включить приватные импорты в модуле с помощью флага -enable-private-imports и использовать условную компиляцию в тестах.@_private только в тестах, оборачивая его в условные флаги компиляции для обеспечения гибкости и возможности отключения при изменениях в Swift.Please open Telegram to view this post
VIEW IN TELEGRAM
❤🔥1❤1🔥1
На днях команда Swift выпустила…
Странный шаг, честно говоря.
KMP вроде бы не стал панацей, с чего вдруг это сработает в обратную сторону… Swift SDK для Android доступен для загрузки с установщика Windows или отдельно для Linux и macOS.Swift для Android.Swift Package Index уже совместимы с Android, что упрощает портирование существующих пакетов.Android разрабатывает документ видения, который определит приоритетные направления для будущей работы с Swift на Android.Please open Telegram to view this post
VIEW IN TELEGRAM
🤯7👍5❤🔥1
Thread-Safe Classes: GCD vs Actors
⚙️ Многопоточность и гонки данных являются распространенными проблемами в программировании, особенно при работе с общими ресурсами, такими как словари.
➡️ Использование конкурентной очереди и синхронных/асинхронных вызовов позволяет создать потокобезопасный кэш, предотвращая гонки данных и обеспечивая целостность состояния.
➡️ Лучшей практикой является использование барьеров для обеспечения эксклюзивного доступа к ресурсам при записи, что позволяет одновременно выполнять чтение.
➡️ Акторы обеспечивают безопасность параллелизма, позволяя только одной задаче одновременно получать доступ к изолированному состоянию, что упрощает синхронизацию.
✔️ Сравнение различных подходов к потокобезопасности показывает, что использование акторов является наиболее современным и безопасным методом для работы с многопоточностью в Swift.
Хорошая статья с кучей примеров, рекомендую к прочтению.👍
Хорошая статья с кучей примеров, рекомендую к прочтению.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3❤🔥1
Singletons with Swift Concurrency
🖥 Синглтоны представляют собой глобальное состояние, что делает их источником проблем в многопоточном окружении, так как они не являются потокобезопасными.
⚠️ Рекомендуется избегать использование синглтонов и вместо этого использовать паттерн корня компоновки или передавать аргументы в функции.
🔍 Аннотация
➡️ Среди альтернатив синглтонам рассматриваются кастомные актеры, использование блокировок и аннотация
😲 А вы знали, что у Apple есть тоже документация по синглтонам?
@MainActor позволяет гарантировать потокобезопасный доступ к синглтону, что упрощает аудит и выявление проблем в коде.@unchecked Sendable, но каждая из этих опций имеет свои недостатки.Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
Understanding task cancellation and lifetimes in Swift concurrency
ℹ️ В Swift
➡️ Несструктурированные задачи, созданные с помощью
➡️ При работе с долгоживущими задачами, такими как
⚠️ Отмена задач в Swift не останавливает их немедленно, а устанавливает флаг отмены, который асинхронные операции могут проверять для корректного завершения.
structured concurrency связывает время жизни асинхронной работы с областью, в которой она была создана, автоматически отменяя задачи при завершении этой области.Task { ... }, работают независимо и требуют ручной отмены, в то время как Task.detached выполняется полностью независимо от контекста вызова.AsyncStream, важно управлять временем жизни задачи, чтобы избежать бесконечного выполнения.Please open Telegram to view this post
VIEW IN TELEGRAM
👍3