Запись в файловую систему занимает слишком много времени - PullRequest
0 голосов
/ 05 июня 2018

Я пытаюсь загрузить около 300-400 файлов изображений, используя оптимальное количество потоков (около 20-30), а затем записываю эти изображения в файловую систему Android.Проблема в том, что весь процесс занимает 10-13 минут, и я хочу запустить его примерно через 2-3 минуты с высокоскоростным Интернетом
Я думаю, что этого можно достичь, так как размер этих 300-400 файлов изображений находится втолько некоторые КБ (общий размер будет около 80-100 МБ)
Вот мой код для скачивания и сохранения файла

            long t1 = System.currentTimeMillis();

            Call<ResponseBody> call=apiService.fetchAttachmentDetail(att_id,token,true,device_id, 0.0f, 0.0f);

            Response<ResponseBody> response = call.execute();
            long t2 = System.currentTimeMillis();
            Help.E("downloaded " + att_id + "and time taken in mili second " + (t2 - t1));
            Help.E("content length- " + response.body().contentLength());

            String str = response.headers().get("Content-Type");
            if (str == null)
                str = "/png";
            String ext_type = str.substring(str.indexOf("/") + 1);
            InputStream in = null;
            FileOutputStream out = null;
            ContextWrapper cw = new ContextWrapper(context);
            String fileName = "";
            File directory = cw.getDir(AttachmentDirName, Context.MODE_PRIVATE);
            try {
                in = response.body().byteStream();
                fileName = String.valueOf(att_id) + "." + ext_type;
                File file = new File(directory, fileName);
                out = new FileOutputStream(file);

                int c;
                while ((c = in.read()) != -1) {
                    out.write(c);
                }
            } catch (IOException e) {
                Log.d("Error", e.toString());
                emitter.onError(e);
            } finally {
                if (in != null) {
                    in.close();
                }
                if (out != null) {
                    out.close();
                }
            }

            long t3 = System.currentTimeMillis();

            Help.E("saved " + att_id + "time taken in saving the file " + (t3 - t2));

1 Ответ

0 голосов
/ 05 июня 2018

Вы читаете и записываете свои данные побайтно, это занимает значительно больше времени по сравнению с чтением и записью в буфер.Попробуйте использовать этот метод:

public static void copyStream(InputStream input, OutputStream output)
    throws IOException
{
    byte[] buffer = new byte[1024]; // Adjust if you want
    int bytesRead;
    while ((bytesRead = input.read(buffer)) != -1)
    {
        output.write(buffer, 0, bytesRead);
    }
}

Таким образом, вы замените

int c;
while ((c = in.read()) != -1) {
   out.write(c);
}

на

copyStream(in, out);
...