我正在尝试制作一个应用程序,可以帮助我评估从Web资源下载文件的时间。我发现2个样品:更新进度对话框
Download a file with Android, and showing the progress in a ProgressDialog
和
http://www.helloandroid.com/tutorials/how-download-fileimage-url-your-device
第二个例子显示了一个更小的下载时间,但我不知道如何使用它来更新进度对话框。我认为应该用第二种情况下的“while”表达来完成,但我找不到。有人能给我任何建议吗?
UPD:
第一代码:
try {
time1 = System.currentTimeMillis();
URL url = new URL(path);
URLConnection conexion = url.openConnection();
conexion.connect();
// this will be useful so that you can show a tipical 0-100% progress bar
int lenghtOfFile = conexion.getContentLength();
// downlod the file
InputStream input = new BufferedInputStream(url.openStream());
OutputStream output = new FileOutputStream("/sdcard/analyzer/test.jpg");
byte data[] = new byte[1024];
long total = 0;
time11 = System.currentTimeMillis();
while ((count = input.read(data)) != -1) {
total += count;
// publishing the progress....
publishProgress((int)(total*100/lenghtOfFile));
output.write(data, 0, count);
}
time22= System.currentTimeMillis()-time11;
output.flush();
output.close();
input.close();
} catch (Exception e) {}
timetaken = System.currentTimeMillis() - time1;
第二码:
long time1 = System.currentTimeMillis();
DownloadFromUrl(path, "test.jpg");
long timetaken = System.currentTimeMillis() - time1;
凡
public void DownloadFromUrl(String imageURL, String fileName) { //this is the downloader method
try {
URL url = new URL(imageURL); //you can write here any link
File file = new File(fileName);
/*Open a connection to that URL. */
URLConnection ucon = url.openConnection();
/*
* Define InputStreams to read from the URLConnection.
*/
InputStream is = ucon.getInputStream();
BufferedInputStream bis = new BufferedInputStream(is);
/*
* Read bytes to the Buffer until there is nothing more to read(-1).
*/
ByteArrayBuffer baf = new ByteArrayBuffer(50);
int current = 0;
while ((current = bis.read()) != -1) {
baf.append((byte) current);
}
/* Convert the Bytes read to a String. */
FileOutputStream fos = new FileOutputStream(PATH+file);
fos.write(baf.toByteArray());
fos.close();
} catch (IOException e) {
Log.d("ImageManager", "Error: " + e);
}
所以事情是,第一种方法似乎是慢约30%。
我在Asynctask中执行第二种方法。 – StalkerRus 2011-04-02 18:31:15
那么,第一个代码有一个1024字节的缓冲区,而第二个只有50个。 – trashgod 2011-04-02 18:38:00
我试图减少到50的缓冲区。但我没有看到任何性能的变化。 – StalkerRus 2011-04-02 18:53:29