Я пытаюсь более точно понять «Закрытие» Swift.
Но @escaping и Completion Handlerих слишком сложно понять
Я просмотрел множество сообщений Swift и официальных документов, но чувствовал, что этого все еще недостаточно.
Это пример кода официальных документов
var completionHandlers: [()->Void] = []
func someFunctionWithEscapingClosure(completionHandler: @escaping ()->Void){
completionHandlers.append(completionHandler)
}
func someFunctionWithNoneescapingClosure(closure: ()->Void){
closure()
}
class SomeClass{
var x:Int = 10
func doSomething(){
someFunctionWithEscapingClosure {
self.x = 100
//not excute yet
}
someFunctionWithNoneescapingClosure {
x = 200
}
}
}
let instance = SomeClass()
instance.doSomething()
print(instance.x)
completionHandlers.first?()
print(instance.x)
Я слышал, что есть два способа и причины использования @escaping
Первый предназначен для хранения закрытия, второй - для операционных целей Async.
Следующие мои вопросы :
Во-первых, если doSomethingвыполняется, тоsomeFunctionWithEscapingClosure будет выполняться с параметром закрытия, и это закрытие будет сохранено в массиве глобальных переменных.
Я думаю, что закрытие {self.x = 100}
Как selfв {self.x = 100}, сохраненном в глобальной переменной, completionHandlersможно подключиться к instanceэтому объектуSomeClass ?
Во-вторых, я так понимаю someFunctionWithEscapingClosure.
Чтобы сохранить закрытие локальной переменной completionHandlerдля глобальной переменной, 'завершенияHandlers we using@ escaping` ключевое слово!
без возврата @escapingключевого слова someFunctionWithEscapingClosureлокальная переменная completionHandlerбудет удалена из памяти
@escaping держать это закрытие в памяти
Это правильно?
Наконец, я просто задаюсь вопросом о существовании этой грамматики.
Возможно, это очень элементарный вопрос.
Если мы хотим, чтобы какая-то функция выполнялась после определенной функции. Почему бы нам просто не вызвать какую-то функцию после вызова определенной функции?
В чем разница между использованием указанного выше шаблона и функцией обратного вызова с экранированием?
