Сбой: com.apple.root.default-qos
У меня довольно простое приложение, которое анализирует канал RSS и показывает его содержимое в виде таблицы. Он доступен в App Store. У меня есть Crashlytics crash отчетности интегрированы. Недавно я получил два отчета. Это немного сложно расшифровать.
Это произошло в iPhone 6 под управлением iOS 10.2.1.
![введите описание изображения здесь]()
Это из iPhone 5 с iOS 10.2.1.
![введите описание изображения здесь]()
Несмотря на то, что он говорит, что он сбой из-за нарушений конфиденциальности, я не получаю доступа к службам, требующим разрешения в моем приложении.
Также поиск по com.apple.root.default-qos заставляет меня думать, что это может иметь какое-то отношение к фоновым потокам. Единственное место, где я использую фоновый поток, - это проанализировать данные RSS-фида.
DispatchQueue.global(qos: .background).async {
guard let data = try? Data(contentsOf: URL) else {
return
}
do {
let xmlDoc = try AEXMLDocument(xml: data)
if let items = xmlDoc.root["channel"]["item"].all {
self.posts.removeAll()
for item in items {
let title = item["title"].value ?? ""
// ...
self.posts.append(jobPost)
}
DispatchQueue.main.async {
self.saveposts(self.posts)
self.posts.sort { $0.publishDate > $1.publishDate }
self.tableView.reloadData()
UIApplication.shared.toggleNetworkActivityIndicator(show: false)
self.toggleUI(enable: true)
if self.refreshControl.isRefreshing { self.refreshControl.endRefreshing() }
}
}
} catch let error as NSError {
print("RSS parsing failed: \(error)")
self.showErrorAlert(error)
UIApplication.shared.toggleNetworkActivityIndicator(show: false)
self.toggleUI(enable: true)
if self.refreshControl.isRefreshing { self.refreshControl.endRefreshing() }
}
}
Я протестировал этот код на своем iPhone 5 под управлением iOS 9.3.5 и симуляторах с iOS 10.2, но не произошел сбой.
Есть ли другой способ отследить эту проблему?
Ответы
Ответ 1
Я бы дважды проверял все ваши разрешения. В моем случае, начиная с iOS10, вам нужны разрешения на сохранение материала для рулона камеры пользователя. В моем приложении я показывал общий листок по умолчанию, и всякий раз, когда пользователь выбирал "сохранить фотографию", приложение разбилось с одним из этих очень не полезных сообщений об ошибках. Я добавил
<key>NSPhotoLibraryAddUsageDescription</key>
<string>Allow you to save charts and graphs from the app to your phone.</string>
к моим info.plist
, clean
и run
. И все проблемы были решены.