为什么我的流复制过程的性能会逐渐降低

问题描述 投票:3回答:2

在复制大文件期间,此代码的工作速度越来越慢。难道我做错了什么?

    InputStream ms2 = new BufferedInputStream(new FileInputStream("/home/fedd/Videos/homevid.mp4"));
    OutputStream fos2 = new BufferedOutputStream(new FileOutputStream("testfile2.mp4", true));

    try {
        int byt;
        int i = 0;
        long time = System.currentTimeMillis();
        while ((byt = ms2.read()) != -1) {
            fos2.write(byt);
            i++;
            if (i > 100000) {
                i = 0;
                long took = System.currentTimeMillis() - time;
                System.out.println("100000 bytes took " + took + " milliseconds which means " + (100000000 / took) + " bytes per second");
            }
        }
        fos2.close();
        ms2.close();
    } catch (Exception e) {
        throw new RuntimeException(e);
    }

我的Java是:

openjdk 10.0.2 2018-07-17 OpenJDK运行时环境(build 10.0.2 + 13-Ubuntu-1ubuntu0.18.04.4)

OpenJDK 64位服务器VM(内置10.0.2 + 13-Ubuntu-1ubuntu0.18.04.4,混合模式)

java java-io
2个回答
6
投票

每次比较后,您需要重置基准'时间'。试试这个:

if (i > 100000) {
    i = 0;
    long took = System.currentTimeMillis() - time;
    time = System.currentTimeMillis();
    System.out.println("100000 bytes took " + took + " milliseconds which means " + (100000000 / took) + " bytes per second");
}

5
投票

由于计算错误,性能会下降。对于第二个块,您将从第二个块大小计算每秒的字节数,但是从两个块时间计算。尝试在time = System.currentTimeMillis();之后添加long took = ...

© www.soinside.com 2019 - 2024. All rights reserved.