Найкращою практикою є визначення функції багаторазового використання, до якої можна отримати доступ кілька разів.
ПОСТАВНА ФУНКЦІЯ:
наприклад, десь як AppDelegate.swift як глобальна функція.
func backgroundThread(_ delay: Double = 0.0, background: (() -> Void)? = nil, completion: (() -> Void)? = nil) {
dispatch_async(dispatch_get_global_queue(Int(QOS_CLASS_USER_INITIATED.value), 0)) {
background?()
let popTime = dispatch_time(DISPATCH_TIME_NOW, Int64(delay * Double(NSEC_PER_SEC)))
dispatch_after(popTime, dispatch_get_main_queue()) {
completion?()
}
}
}
Примітка: в Swift 2.0, замініть QOS_CLASS_USER_INITIATED.value вище QOS_CLASS_USER_INITIATED.rawValue замість
ВИКОРИСТАННЯ:
A. Щоб запустити процес у фоновому режимі із затримкою на 3 секунди:
backgroundThread(3.0, background: {
// Your background function here
})
B. Щоб запустити процес у фоновому режимі, потім запустіть завершення на передньому плані:
backgroundThread(background: {
// Your function here to run in the background
},
completion: {
// A function to run in the foreground when the background thread is complete
})
C. Для затримки на 3 секунди - зверніть увагу на використання параметра завершення без фонового параметра:
backgroundThread(3.0, completion: {
// Your delayed function here to be run in the foreground
})