在第一節中,我們使用Handler、Thread/Runnable 、URL、HttpURLConnection等等來進行非同步下載網狀圖片。然後第二節中換了AsyncTask方式。那麼這一節我們再應用其他方式,這個方式與第一節有點雷同,感覺走了一圈回到原地,只是風景更加美麗。人生很多時候也是如此,從NULL中來再回到NULL中。
那麼它是誰呢?java.util.concurrent
java.util.concurrent 是在並發編程中很常用的工具 + 生產力類。
ExecutorService類:具有服務生命週期的Executors。
Executors 類:執行器,將為你管理Thread 對象。
我們知道這些是用來處理並發任務的,當然我們Demo只是請求一張圖片而已,並不能體現並發,但是假設我們有一個ListView,裡面每一項都需要一張網狀圖片顯示呢?那麼並發性就可以體現出來了:多個線程並發從網路下載圖片。當然這個版本不會使用listView顯示多個項圖片,以後做個版本吧!研究下。
思路是這樣的:
1:動態建立N個線程,防線上程池中。
2:系統從線程池中取出一個線程投入執行,線程池中若沒有線程可用,其他任務只有先等待了,直到有新線程釋放,才調用。
如下有幾個方法可以動態指定多少個線程。
newFixedThreadPool(int nThreads) 指定線程個數
newCachedThreadPool() 系統為每個任務都建立一個線程
下面可以實現並發下載資料
View Code
case R.id.btnThress:
progress.setVisibility(View.VISIBLE);
final Handler newhandler=new Handler();
executorService.submit(new Runnable(){
@Override
public void run() {
try {
URL newurl = new URL(params);
HttpURLConnection conn = (HttpURLConnection)newurl.openConnection();
conn.setDoInput(true);
conn.connect();
InputStream inputStream=conn.getInputStream();
bitmap = BitmapFactory.decodeStream(inputStream);
newhandler.post(new Runnable(){
@Override
public void run() {
ImageView view=(ImageView)frameLayout.findViewById(R.id.image);
view.setImageBitmap(bitmap);
}
});
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
});
break;
運行結果為: