多线程:Callable
Callable接口提供一個(gè)call()方法可以作為線程執(zhí)行體。與run()方法不同的是:
call()方法具有返回值!還可以聲明異常!
?
創(chuàng)建并啟動(dòng)有返回值的線程步驟如下:
1)創(chuàng)建Callable的實(shí)現(xiàn)類,并實(shí)現(xiàn)call()方法。JAVA8開始可以使用lambda函數(shù)創(chuàng)建callable對(duì)象。
FutureTask<Integer> task = new FutureTask<Integer>((Callable<Integer>)()->{int i = 0;for(;i<10;i++){//do something.}return i; });2)?使用Future接口的實(shí)現(xiàn)類FutureTask來(lái)封裝Callable對(duì)象,可以通過(guò)這個(gè)類來(lái)獲得callable對(duì)象的返回值。
3)使用FutureTask對(duì)象作為Thread對(duì)象的Target創(chuàng)建并啟動(dòng)線程
new Thread(task).start();4)調(diào)用FutureTask對(duì)象的get()方法來(lái)獲取子線程執(zhí)行結(jié)束之后的返回值。
task.get();get()方法會(huì)使得主線程阻塞!直到call()方法結(jié)束并返回為止!
使用場(chǎng)景:FutureTask 可用于異步獲取執(zhí)行結(jié)果或取消執(zhí)行任務(wù)的場(chǎng)景。當(dāng)一個(gè)計(jì)算任務(wù)需要執(zhí)行很長(zhǎng)時(shí)間,那么就可以用 FutureTask 來(lái)封裝這個(gè)任務(wù),主線程在完成自己的任務(wù)之后再去獲取結(jié)果。
總結(jié)
以上是生活随笔為你收集整理的多线程:Callable的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Redis:redis和memcache
- 下一篇: @RestController/@Con