本文目錄一覽:
java future函數的作用
在並發編程時,一般使用runnable,然後扔給線程池完事,這種情況下不需要線程的結果。
所以run的返回值是void類型。
如果是一個多線程協作程序,比如菲波拉切數列,1,1,2,3,5,8…使用多線程來計算。
但後者需要前者的結果,就需要用callable介面了。
callable用法和runnable一樣,只不過調用的是call方法,該方法有一個泛型返回值類型,你可以任意指定。
線程是屬於非同步計算模型,所以你不可能直接從別的線程中得到函數返回值。
這時候,Future就出場了。Futrue可以監視目標線程調用call的情況,當你調用Future的get()方法以獲得結果時,當前線程就開始阻塞,直接call方法結束返回結果。
什麼是java future模式
Future介紹
用過Java並發包的朋友或許對Future (interface) 已經比較熟悉了,其實Future 本身是一種被廣泛運用的並發設計模式,可在很大程度上簡化需要數據流同步的並發應用開發。
Future模式可以簡單的看成是 Proxy 模式 與 Thread-Per-Message 模式 的結合,在Proxy模式中,用一個Proxy來代替真正的目標(Subject)生成,目標的生成可能是費時的,例如在開啟一個內嵌圖片的文件中,希望程式能儘快完成開啟文件的動作,並顯示一個可接受的畫面給使用者看,在還不需要看到圖片的頁面中先使用Proxy代替真正的圖片載入,只有在真正需要看到圖片時,才由Proxy物件載入真正的圖片。
考慮這樣一個情況,使用者可能快速翻頁瀏覽文件中,而圖片檔案很大,如此在瀏覽到有圖片的頁數時,就會導致圖片的載入,因而造成使用者瀏覽文件時會有停頓的現象,所以我們希望在文件開啟之後,仍有一個背景作業持續載入圖片,如此使用者在快速瀏覽頁面時,所造成的停頓可以獲得改善。
Future模式在請求發生時,會先產生一個Future物件給發出請求的客戶,它的作用就像是Proxy物件,而同時間,真正的目標物件之生成,由一個新的執行緒持續進行(即Thread-Per-Message),真正的目標物件生成之後,將之設定至Future之中,而當客戶端真正需要目標物件時,目標物件也已經準備好,可以讓客戶提取使用。
這裡就以java.util.concurrent.Future 為例簡單說一下Future的具體工作方式。Future對象本身可以看作是一個顯式的引用,一個對非同步處理結果的引用。由於其非同步性質,在創建之初,它所引用的對象可能還並不可用(比如尚在運算中,網路傳輸中或等待中)。這時,得到Future的程序流程如果並不急於使用Future所引用的對象,那麼它可以做其它任何想做的事兒,當流程進行到需要Future背後引用的對象時,可能有兩種情況:
希望能看到這個對象可用,並完成一些相關的後續流程。如果實在不可用,也可以進入其它分支流程。
「沒有你我的人生就會失去意義,所以就算海枯石爛,我也要等到你。」(當然,如果實在沒有毅力枯等下去,設一個超時也是可以理解的)
求大神,Java自帶的Future多線程模式是什麼意思
理1:
什麼是Future?
用過Java並發包的朋友或許對Future (interface) 已經比較熟悉了,其實Future
本身是一種被廣泛運用的並發設計模式,可在很大程度上簡化需要數據流同步的並發應用開發。在一些領域語言(如Alice ML
)中甚至直接於語法層面支持Future。
這裡就以java.util.concurrent.Future
為例簡單說一下Future的具體工作方式。Future對象本身可以看作是一個顯式的引用,一個對非同步處理結果的引用。由於其非同步性質,在創建之初,它
所引用的對象可能還並不可用(比如尚在運算中,網路傳輸中或等待中)。這時,得到Future的程序流程如果並不急於使用Future所引用的對象,那麼
它可以做其它任何想做的事兒,當流程進行到需要Future背後引用的對象時,可能有兩種情況:
希望能看到這個對象可用,並完成一些相關的後續流程。如果實在不可用,也可以進入其它分支流程。
「沒有你我的人生就會失去意義,所以就算海枯石爛,我也要等到你。」(當然,如果實在沒有毅力枯等下去,設一個超時也是可以理解的)
對於前一種情況,可以通過調用Future.isDone()判斷引用的對象是否就緒,並採取不同的處理;而後一種情況則只需調用get()或
get(long timeout, TimeUnit unit)通過同步阻塞方式等待對象就緒。實際運行期是阻塞還是立即返回就取決於get()的調用時機和對象就緒的先後了。
整理二:
什麼是Future模式呢?Future
顧名思義,在金融行業叫期權,市場上有看跌期權和看漲期權,你可以在現在(比如九月份)購買年底(十二月)的石油,假如你買的是看漲期權,那麼如果石油真
的漲了,你也可以在十二月份依照九月份商定的價格購買。扯遠了,Future就是你可以拿到未來的結果。對於多線程,如果線程A要等待線程B的結果,那麼
線程A沒必要等待B,直到B有結果,可以先拿到一個未來的Future,等B有結果是再取真實的結果。其實這個模式用的很多,比如瀏覽器下載圖片的時候,
剛開始是不是通過模糊的圖片來代替最後的圖片,等下載圖片的線程下載完圖片後在替換。
補充:
當另外一個線程需要使用某一個線程的結果時,可以通過Future引用的get()方法去獲得,如果結果還未出來,調用此方法的線程被block,直到結果出來。(這種機制是為了更好地適應多線程環境)
原創文章,作者:KDDYS,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/317854.html