1. 程式人生 > >HttpURLConnection之斷點續傳(多執行緒下載)

HttpURLConnection之斷點續傳(多執行緒下載)

public class MainActivity extends Activity {
   private static final int PROCESSING = 1;
   private static final int FAILURE = -1;
   private EditText pathText;
   private TextView resultView;
   private Button downloadButton;
   private Button stopButton;
/**進度條*/
private ProgressBar progressBar;
   private 
Handler handler = new UIHandler(); /** * 當Handler被建立會關聯到建立它的當前執行緒的訊息佇列,該類用於往訊息佇列傳送訊息 * 訊息佇列中的訊息由當前執行緒內部進行處理 */ private final class UIHandler extends Handler { public void handleMessage(Message msg) { switch (msg.what) { case PROCESSING: // progressBar.setProgress(msg.getData().getInt("size"
)); //已經下載的佔總的大小的百分比 float fraction = (float) progressBar.getProgress() / (float) progressBar.getMax(); //當前已經下載的大小 int currentLength = (int) (fraction * 100); resultView.setText(currentLength + "%"); if (progressBar.getProgress() == progressBar.getMax()) { Toast.makeText(getApplicationContext(),
R.string.success, Toast.LENGTH_LONG).show(); } break; case FAILURE: // 下載失敗 Toast.makeText(getApplicationContext(), R.string.error, Toast.LENGTH_LONG).show(); break; } } } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); pathText = (EditText) findViewById(R.id.path); resultView = (TextView) findViewById(R.id.resultView); downloadButton = (Button) findViewById(R.id.downloadbutton); stopButton = (Button) findViewById(R.id.stopbutton); progressBar = (ProgressBar) findViewById(R.id.progressBar); ButtonClickListener listener = new ButtonClickListener(); downloadButton.setOnClickListener(listener); stopButton.setOnClickListener(listener); pathText.setText("http://img3.iqilu.com/data/attachment/forum/201308/21/192654ai88zf6zaa60zddo.jpg"); } private final class ButtonClickListener implements View.OnClickListener { @Override public void onClick(View v) { switch (v.getId()) { case R.id.downloadbutton: //開始下載 String path = pathText.getText().toString(); String filename = path.substring(path.lastIndexOf('/') + 1); try { filename = URLEncoder.encode(filename, "UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } path = path.substring(0, path.lastIndexOf("/") + 1) + filename; if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) { File savDir = Environment.getExternalStorageDirectory(); download(path, savDir); } else { Toast.makeText(getApplicationContext(), R.string.sdcarderror, Toast.LENGTH_LONG).show(); } downloadButton.setEnabled(false); stopButton.setEnabled(true); break; case R.id.stopbutton: // 停止下載 exit(); Toast.makeText(getApplicationContext(), "Now thread is Stopping!!", Toast.LENGTH_LONG).show(); downloadButton.setEnabled(true); stopButton.setEnabled(false); break; } } private DownloadTask task; private void exit() { if (task != null) task.exit(); } private void download(String path, File savDir) { task = new DownloadTask(path, savDir); new Thread(task).start(); } private final class DownloadTask implements Runnable { private String path; private File saveDir; private FileDownloader loader; public DownloadTask(String path, File saveDir) { this.path = path; this.saveDir = saveDir; } public void exit() { if (loader != null) loader.exit(); } DownloadProgressListener downloadProgressListener = new DownloadProgressListener() { @Override public void onDownloadSize(int size) { Message msg = new Message(); msg.what = PROCESSING; msg.getData().putInt("size", size); handler.sendMessage(msg); } }; @Override public void run() { try { //構造下載器 loader = new FileDownloader(getApplicationContext(), path, saveDir, 3); progressBar.setMax(loader.getFileSize()); //開始下載 loader.download(downloadProgressListener); } catch (Exception e) { e.printStackTrace(); handler.sendMessage(handler.obtainMessage(FAILURE)); } } } } }
效果圖:

相關推薦

HttpURLConnection斷點執行下載

public class MainActivity extends Activity { private static final int PROCESSING = 1; private static final int FAILURE = -1; private EditText pat

斷點執行下載

多執行緒下載 原理:伺服器CPU分配給每條執行緒的時間片相同,伺服器頻寬平均分配給每條執行緒,所以客戶端開啟的執行緒越多,就能搶佔到更多的伺服器資源,所以使用多執行緒下載的話,速度會更快。 JavaSE實現帶斷點續傳的多執行緒下載步驟: 1、傳送http請求至下載地址,獲取要下載

【轉】文件下載斷點客戶端與服務端的實現

http協議 當前時間 end box [] ada demo 服務端 sem 【轉】文件下載之斷點續傳(客戶端與服務端的實現) 【轉】文件下載之斷點續傳(客戶端與服務端的實現) 前面講了文件的上傳,今天來聊聊文件的下載。 老規矩,還是從最簡單粗暴的開始。那麽多簡單算簡單

java&android執行池-Executor框架ThreadPoolExcutor&ScheduledThreadPoolExecutor淺析執行程式設計

java多執行緒-概念&建立啟動&中斷&守護執行緒&優先順序&執行緒狀態(多執行緒程式設計之一)java多執行緒同步以及執行緒間通訊詳解&消費者生產者模式&死鎖&Thread.join()(多執行緒程式設計之二)

UnityWebRequest下載網路資源,支援斷點檔案同時下載

今晚研究了下關於Unity中檔案下載的斷點續傳功能,Unity已經封裝了網路資源的下載API,當然也可以使用C#中的API進行資源下載。     首先說一下斷點續傳的大概思路:     1、下載一個檔案時,向伺服器傳送下載請求,傳送一個Range的報文,指定從檔案資料的什麼位

24執行3

1 單例設計模式 保證類在記憶體中只有一個物件。有三種寫法,下面分別介紹 (1)餓漢式 為什麼叫它餓漢式寫法呢,因為它在建立類的時候,不管三七二十一就直接建立了s物件,也不管s會不會被使用,相反,還有一種寫法叫懶漢式寫法。 (2)懶漢式(單例延遲載入模式) 多執行

23執行2

1 休眠執行緒 2 守護執行緒 這個概念需要解釋一下,以象棋為例,非守護執行緒相當於帥,守護執行緒相當於車馬相士,當帥都沒了,車馬相士就失去了它的意義了,就是非守護執行緒停止了,守護執行緒也就gg了。 結果就是aaaa不會輸出50次了。 3 加入執行緒(插隊執行緒)

22執行1

1 多執行緒 2 多執行緒的原理 3 並行和併發的區別 4 java是多執行緒嗎 5 多執行緒的實現方式一(繼承Thread) 6 多執行緒的實現方式二(實現Runnable) 7 兩種方式的區別 8 匿名內部類實現執行

Python 實用程式設計技巧執行

一、GIL(global_interpreter_lock) 1.概念: Python 一開始為了簡單,在多執行緒程式設計的時候會在我們的直譯器上加一個非常大的鎖,也就是允許我們一次只有一個執行緒執行在一個CPU上,gil 就能實現在同一時刻只有一個執行緒在CPU上執行位

【DP】ssl 1010 方格取數執行DP

Description 設有N*N的方格圖(N<=10,我們將其中的某些方格中填入正整數,而其他的方格中則放入數字0。如下圖所示(見樣例):   某人從圖的左上角的A 點出發,可以向下行走,也可以向右走,直到到達右下角的B點。在走過的路上,他可以取走方格中的數(取走後的方格中將變

Python 計算從1-10000內的素數執行demo

Python 計算從1-10000內的素數 素數:質數定義為在大於1的自然數中,除了1和它本身以外不再有其他因數。 利用for迴圈從1-10000將值賦值給i 在函式中判斷i是否為素數,用這個數求餘這個數以內的數判斷餘數是否為0 素數返回True,不是素數返回Fals

工一執行基礎

併發,並行 併發:指的是任務數多餘cpu核數,通過作業系統的各種任務排程演算法,實現用多個任務“一起”執行(實際上總有一些任務不在執行,因為切換任務的速度相當快,看上去一起執行而已) 並行:指的是任務數小於等於cpu核數,即任務真的是一起執行的 多執行緒執行

linux c++執行池的實現執行伺服器

        本文給出了一個通用的執行緒池框架,該框架將與執行緒執行相關的任務進行了高層次的抽象,使之與具體的執行任務無關。另外該執行緒池具有動態伸縮性,它能根據執行 任務的輕重自動調整執行緒池中執行緒的數量。文章的最後,我們給出一個簡單示例程式,通過該示例程式,我們會發

作業系統上機題目執行2

主執行緒建立4個子執行緒T1、T2、T3、T4, 主執行緒在4個子執行緒退出後,才退出 執行緒T1、T2、T3、T4的執行時程式碼如下: #include <unistd.h> // sleep函式宣告在該標頭檔案中 void *T1_e

關於java中併發時引起的問題執行問題

場景如下: 我有一個訂單匯入頁面,如下圖: 公司裡面有很多員工,都需要進入這個頁面,進行訂單匯入。 併發進行,可能存在這樣的問題,兩個同事,同時輸了一個相同的訂單號,同時點選訂單匯入,同時匯入成功。 那麼資料庫中就會存在兩條一模一樣的訂單資料。 上面的問題是多執行緒引發

執行斷點

一、 學習內容 1、 多檔案下載列表的顯示 2、 啟動多個執行緒分段下載 二、 多執行緒下載原理簡介 假設要分3個執行緒下載一個100位元組的檔案:從頭到尾,每個執行緒下載一段 三、 學習點 1、 Adapter的getCount() 2、 A

執行斷點

一、 學習內容 1、 基本UI定義 2、 資料庫的操作 3、 Service的啟動 4、 Activity給service傳遞引數 5、 使用廣播回傳資料到Activity 6、 執行緒和Handler 7、 網路操作:檔案的寫入,網路往本地磁碟寫入 二、 網路下

Java執行下載器FileDownloader支援斷點、代理等功能

前言 在我的任務清單中,很早就有了一個檔案下載器,但一直忙著沒空去寫。最近剛好放假,便抽了些時間完成了下文中的這個下載器。 介紹 同樣的,還是先上效果圖吧。 Jar包地址位於 FileDownloader 目前實現的主要功能有: 多執行緒下載 斷點續傳 自定義頭部等 即將完成的包括: 新增代理功

ASP.NET WebAPi斷點下載

前言 上一篇我們穿插了C#的內容,本篇我們繼續來講講webapi中斷點續傳的其他情況以及利用webclient來實現斷點續傳,至此關於webapi斷點續傳下載以及上傳內容都已經全部完結,一直嚷嚷著把SQL Server和Oracle資料庫再重新過一遍,這篇過完,就要開始

Android 實現執行下載檔案+斷點

                            Android 多執行緒下載檔案+斷點續傳       在專案快要結束的時候,發現了app沒有版本更新的功能,於是找到一些過去的資料,在app上應用完成了版本更新,現在記錄一下apk的下載,也就是如何通過多執行緒將ap