.NET 4.6中任務(wù)并行庫的特性是什么呢,針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評估等整套的建站服務(wù),主營業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站,成都app開發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
在即將發(fā)布的.NET 4.6中,.NET中的任務(wù)并行庫將會(huì)進(jìn)行某些調(diào)整。其中會(huì)包括一些新的幫助方法以減少代碼量,可能還會(huì)有性能方面的優(yōu)化。除此之外,TPL將會(huì)通過使用一個(gè)新的解決方案對SetResult方法中某個(gè)復(fù)雜的問題進(jìn)行處理。
可以將Task.FromResult視為一個(gè)典型樣板,這一函數(shù)用于創(chuàng)建一個(gè)已經(jīng)完成的Task對象,而無需首先創(chuàng)建一個(gè)TaskCompletionSource對象。開發(fā)者無法模擬這一效果,因此這需要訪問Task類型的內(nèi)部實(shí)現(xiàn),如果你希望在異常處理時(shí)達(dá)到同樣的效果,以上缺陷就將會(huì)成為一個(gè)阻礙。
.NET 4.6通過Task.FromException方法解決了這一問題。與FromResult類似,它能夠繞過TaskCompletionSource這一機(jī)制的使用,并避免了隨之而來的各種消耗。
與之相關(guān)的一個(gè)特性是Task.CompletedTask屬性,該屬性會(huì)返回一個(gè)完成的Task對象,而在目前的版本中只能通過Task.FromResult
與最后一個(gè)重要的特性相比,以上所介紹的這些新特性的效果可謂微不足道。TaskCompletionSource.SetResult方法有一個(gè)已知的行為,即如果該方法的后續(xù)方法會(huì)掛起對應(yīng)的Task對象的話,那么這些后續(xù)方法有可能會(huì)以同步方式進(jìn)行運(yùn)行。Stephen Toub為讀者解釋了為什么這一行為可能會(huì)出現(xiàn)問題
我曾說過對TaskCompletionSource
為了避免這一情況的產(chǎn)生,開發(fā)者可以在創(chuàng)建TaskCompletionSource時(shí),使用RunContinuationsAsynchronously這一新的標(biāo)記:
tcs = new TaskCompletionSource(TaskCreationOptions.RunContinuationsAsynchronously)
關(guān)于.NET 4.6中任務(wù)并行庫的特性是什么呢問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。