Java異步編程最佳實(shí)踐-Java開發(fā)Java經(jīng)驗(yàn)技巧_第1頁
Java異步編程最佳實(shí)踐-Java開發(fā)Java經(jīng)驗(yàn)技巧_第2頁
Java異步編程最佳實(shí)踐-Java開發(fā)Java經(jīng)驗(yàn)技巧_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、java異步編程最佳實(shí)踐-編程開發(fā)技術(shù)java異步編程最佳實(shí)踐譯文出處:丿京文出處:什么是異步?為什么要用它?異步編程提供了一個(gè)非阻塞的,事件驅(qū)動(dòng)的編程模型。這種編程模型利用系統(tǒng) 中多核執(zhí)行任務(wù)來提供并行,因此提供了應(yīng)用的吞葉率。此處吞吐率是指在單位 時(shí)間內(nèi)所做任務(wù)的數(shù)量。在這種編程方式下,一個(gè)工作單元將獨(dú)立于主應(yīng)用線 程而執(zhí)行,并且會(huì)將它的狀態(tài)通知調(diào)用線程:成功,處理中或者失敗。我們需要異步來消除阻塞模型。其實(shí)異步編程模型可以使用同樣的線程來處理多 個(gè)請(qǐng)求,這些請(qǐng)求不會(huì)阻塞這個(gè)線程。想象一個(gè)應(yīng)用正在使用的線程正在執(zhí)行 任務(wù),然后等待任務(wù)完成才進(jìn)行下一步。log框架就是一個(gè)很好的例子:典型 地

2、你想將異常和錯(cuò)誤日志記錄到一個(gè)口標(biāo)屮,比如文件,數(shù)據(jù)庫或者其它類似 地方。你不會(huì)讓你的程序等待日志寫完才執(zhí)行,否則程序的響應(yīng)就會(huì)受到影響。 相反,如果對(duì)log框架的調(diào)用是異步地,應(yīng)用就可以并發(fā)執(zhí)行其它任務(wù)而無需等 待。這是一個(gè)非阻塞執(zhí)行的例子。為了在java中實(shí)現(xiàn)異步,你需要使用future?和?futuretask,它們位于 java. util, concurrent 下.?future是一個(gè)接口而futuretask是它的一個(gè)實(shí)現(xiàn) 類。實(shí)際上,如果在你的代碼中使用future,你的異步任務(wù)會(huì)立即執(zhí)行,并且 調(diào)用線程可以得到結(jié)果promisee下面的代碼片段定義了一個(gè)包含兩個(gè)方法的接口。一

3、個(gè)是同步方法,另外一個(gè) 是界步方法。import java. util, concurrent. future;public i nterface tdatamanager / synchronous methodpublic string getdatasynchronously();/ asynchronous methodpublic future<string> getdataasynchronously();值得注意的是回調(diào)模型的弊端就是當(dāng)回調(diào)歐套時(shí)很麻煩。該做和不該做的 為了方便測(cè)試,你應(yīng)該在代碼中將功能從多線程中隔離出來。當(dāng)在java中編寫 異步代碼時(shí),你應(yīng)該遵循異步

4、模型,這樣調(diào)用線程就不會(huì)被阻塞。注意構(gòu)造函數(shù)不能是異步的,你不應(yīng)該在構(gòu)造函數(shù)中調(diào)用異步方法。當(dāng)任務(wù)互相 不依賴吋異步方式尤其有用。當(dāng)調(diào)用任務(wù)依賴被調(diào)用任務(wù)吋不應(yīng)該使用異步(譯 者按:這對(duì)異步來說無意義,因?yàn)闃I(yè)務(wù)上調(diào)用線程被阻塞了).你應(yīng)該在異步方法小處理異常.你不應(yīng)該為長時(shí)間的task實(shí)現(xiàn)異常.一個(gè)長時(shí) 間運(yùn)行的任務(wù),如果異步執(zhí)行的話,可能會(huì)比同步執(zhí)行耗費(fèi)更長的時(shí)間,因?yàn)?運(yùn)行時(shí)要為異步執(zhí)行的方法執(zhí)行線程上下文的切換,線程狀態(tài)的存儲(chǔ)等.你也 應(yīng)該注意同步的異常和異步的異常有所不同。同步異常暗示每次程序執(zhí)行到那 個(gè)程序特殊狀態(tài)時(shí)就會(huì)拋出異常;異步異常的跟蹤則困難的多。所以同步和異步 異常暗示同步

5、或異步代碼可能拋出異常(synchronous and asynchronous exceptions imply synchronous or asynchronous code in your program that might raise exceptions.)0推薦閱讀1 2 http:/docs.oracic>comyjavacc/6/tutoriai/doc/gkicz.html3. https:/technology.amis.nl/2009/02/19/asynchronous-processing-in-java-applications-leve raging-t

6、hose-multi-cores/4. http:/javarevisited.blogspot.in/20i5/01/how-to-use-future-and-futuretask-in-java.html5. 總結(jié)界步對(duì)于設(shè)計(jì)大規(guī)??焖夙憫?yīng)的應(yīng)用是至關(guān)重要的。開步冋調(diào)模型帶來了很多的 好處;你可以依賴你的異步回調(diào)方法來執(zhí)行昂貴的i/o操作而你的處理器可以執(zhí) 行其它任務(wù)。然而雖然在java和c#中提供了異步的支持,異步編程并不總是那 么容易實(shí)現(xiàn)。異步方式的使用要謹(jǐn)慎:你應(yīng)該清楚什么時(shí)候可以用和什么時(shí)候不 該用。木文屮我們介紹了異步編程的概念,以及使用ja編程需要怎么去實(shí)現(xiàn).本文 也列出了使用異步編程的最佳實(shí)踐。謝謝閱讀。譯者增加的內(nèi)容java 7中提供了 fork/join框架,可以將一個(gè)大的task分割成很多可以并行 執(zhí)行的小tasko java 8 'i1 parallelstream內(nèi)部利用fork/join執(zhí)行并發(fā)操作。 reactive extensions for . net提供了異步和基于事件編程框架,java中對(duì)應(yīng) 的是netflix的rxjava,你可以使用它實(shí)現(xiàn)cqrs和event sourcing模式。akka捉供了一個(gè)分布式的,容錯(cuò)的,事件驅(qū)動(dòng)的框架,可以實(shí)現(xiàn)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論