.net core针对async ()=的安全处理
????????最近在做一個功能需要傳遞一個委托作為回調(diào)邏輯處理,但在使用中定義了async ()=>來處理awaiter邏輯那就存在一個安全問題了。了解async/awaiter的朋友一定清楚async void函數(shù)帶來的致命風(fēng)險!
??????? async void會阻斷異常路由,即當(dāng)前函數(shù)沒有try的情況下出現(xiàn)異常這類異常都是全局未捕獲異常會導(dǎo)致程序直接閃退!代碼如下:
以上OnRun方法中的Try顯然是無法獲捕獲到async ()=>函數(shù)里的異常的,而這程序運(yùn)行的最終結(jié)果拋出異常閃退!
實際應(yīng)用中不使用async ()=>或要求使用者在async ()=>方法定義try來避免這些問題顯然也是不可能的事情。
? ? ? ? 應(yīng)用中Task是支持這種寫法的,而這寫法從框架設(shè)計角度上來說調(diào)用應(yīng)該是安全的,所以看了一下 Task.Run方法;發(fā)現(xiàn)其實.net core的編譯器早已經(jīng)處理了這些問題。
編譯器會把a(bǔ)sync ()=>路由于Run(Func<Task?> function)的函數(shù)版本中,這樣問題就好解決了。
class Program{static void Main(string[] args){OnRun(async () =>{await Task.Delay(1000);throw new Exception("error!");});Console.Read();}private static async void OnRun(Func<Task?> action){try{await action();}catch (Exception e_){Console.WriteLine(e_.Message);}}private static void OnRun(Action action){try{action();}catch (Exception e_){Console.WriteLine(e_.Message);}}}這樣async ()=>異常處理就能還捕獲處理,不會引起程序閃退問題。
注意
????????在代碼中盡可能不要定義async?void函數(shù),可以使用async Task來代替,除非你對async?void函數(shù)危害和如何規(guī)避風(fēng)險有所了解。
開源跨平臺通訊框架(支持TLS)
提供高性能服務(wù)和大數(shù)據(jù)處理解決方案
https://beetlex.io
????????
總結(jié)
以上是生活随笔為你收集整理的.net core针对async ()=的安全处理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: .Net之Swagger基础使用
- 下一篇: NET问答: 如何将 DataTable