Ответы:
Допустим, у вас есть функция загрузки для загрузки файла из сети и вы хотите получать уведомление, когда задача загрузки завершена.
typealias CompletionHandler = (success:Bool) -> Void
func downloadFileFromURL(url: NSURL,completionHandler: CompletionHandler) {
// download code.
let flag = true // true if download succeed,false otherwise
completionHandler(success: flag)
}
// How to use it.
downloadFileFromURL(NSURL(string: "url_str")!, { (success) -> Void in
// When download completes,control flow goes here.
if success {
// download success
} else {
// download fail
}
})
Надеюсь, поможет.
Мне было трудно понять ответы, поэтому я предполагаю, что у любого другого новичка, такого как я, может быть такая же проблема, как и у меня.
Мое решение делает то же самое, что и главный ответ, но, надеюсь, немного более ясное и легкое для понимания для новичков или людей, которые просто не понимают в целом.
Чтобы создать функцию с обработчиком завершения
func yourFunctionName(finished: () -> Void) {
print("Doing something!")
finished()
}
использовать функцию
override func viewDidLoad() {
yourFunctionName {
//do something here after running your function
print("Tada!!!!")
}
}
Ваш результат будет
Делать что-то
Тада !!!
Надеюсь это поможет!
Простой пример Swift 4.0:
func method(arg: Bool, completion: (Bool) -> ()) {
print("First line of code executed")
// do stuff here to determine what you want to "send back".
// we are just sending the Boolean value that was sent in "back"
completion(arg)
}
Как это использовать:
method(arg: true, completion: { (success) -> Void in
print("Second line of code executed")
if success { // this will be equal to whatever value is set in this method call
print("true")
} else {
print("false")
}
})
Для этой цели мы можем использовать замыкания . Попробуйте следующее
func loadHealthCareList(completionClosure: (indexes: NSMutableArray)-> ()) {
//some code here
completionClosure(indexes: list)
}
В какой-то момент мы можем вызвать эту функцию, как указано ниже.
healthIndexManager.loadHealthCareList { (indexes) -> () in
print(indexes)
}
Пожалуйста, перейдите по следующей ссылке для получения дополнительной информации о закрытии .
Swift 5.0 +, простой и короткий
пример:
Стиль 1
func methodName(completionBlock: () -> Void) {
print("block_Completion")
completionBlock()
}
Стиль 2
func methodName(completionBlock: () -> ()) {
print("block_Completion")
completionBlock()
}
Использование:
override func viewDidLoad() {
super.viewDidLoad()
methodName {
print("Doing something after Block_Completion!!")
}
}
Вывод
block_Completion
Что-то делать после Block_Completion !!
Я немного запутался в обработчиках завершения, сделанных на заказ. В вашем примере:
Допустим, у вас есть функция загрузки для загрузки файла из сети и вы хотите получать уведомление, когда задача загрузки завершена.
typealias CompletionHandler = (success:Bool) -> Void
func downloadFileFromURL(url: NSURL,completionHandler: CompletionHandler) {
// download code.
let flag = true // true if download succeed,false otherwise
completionHandler(success: flag)
}
Ваш по- // download code
прежнему будет выполняться асинхронно. Почему код не будет идти прямо на let flag = true
и , completion Handler(success: flag)
не дожидаясь вашей загрузки кода , который будет закончен?