swift escaping逃逸閉包用法

2021-08-28 14:08:08 字數 614 閱讀 9920

func insert (_ region: @escaping region) -> region

}當其中需要執行後才返回, 非同步執行的,都需要新增escaping.

如方法1.

func dowork(block:()->() )

呼叫時:

dowork

這種形式的閉包預設了一種假設, 就是引數中的block的方法會在dowork 返回前就完成。 即對於block的呼叫是同步行為。

而如果我們要把block中的方法放到乙個dispatch中去, 讓它在dowork返回後才去執行, 就需要在block型別前加上@escaping標識這個閉包是會逃逸出呼叫方法的。

方法2:

fun doworkasync( block: @escaping()->() )

}對於上面兩種情況下, 方法1中沒有加escaping的方法, 由於block()閉包可以捕獲其中的變數,沒有逃逸形為的閉包,所以即使裡面有呼叫self的情況,也完全不用擔心持有的問題。

而對於方法2, 由於閉包的作用域可以超函式本身, 所以在這個閉包內部呼叫self及其成員的情況下, 需要強制寫出self. 或者根據情況使用[weak self], 或者[unowned self]

This引用逃逸

this逃逸 this逃逸就是說,在建構函式返回之前,其他執行緒就已經取得了該物件的引用,由於建構函式還沒有完成,所以,物件也可能是殘缺的,所以,取得物件引用的執行緒使用殘缺的物件極有可能發生錯誤的情況。因為這兩個執行緒是非同步的,取得物件引用的執行緒並不一定會等待構造物件的執行緒完結後在使用引用。...

this指標逃逸問題

簡述 this逃逸是指在建構函式返回之前其他縣城就持有該物件的引用。呼叫尚未構造完成的物件的方法可能引起奇怪的問題。this逃逸經常發生在建構函式中啟動執行緒或者註冊 時,例如 public class thisescape private class escaperunnable implemen...

逃逸分析 Escape Analysis)

什麼是逃逸?逃逸是指在某個方法之內置立的物件,除了在方法體之內被引用之外,還在方法體之外被其它變數引用到 這樣帶來的後果是在該方法執行完畢之後,該方法中建立的物件將無法被gc 由於其被其它變數引用。正常的方法呼叫中,方法體中建立的物件將在執行完畢之後,將 其中建立的物件 故由於無法 即成為逃逸。無逃...