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