0

我正在尝试使用 Apache Commons Compress 来读取 7-zip 文件的内容。我对阅读/提取内容不感兴趣,我只想获取所有条目的列表。

我编写了这段代码,但是使用 4MB 的存档需要 6 秒才能读取整个文件。

public static void main(String[]args) throws IOException{
    File sevenz = new File("testfile.7z");
    System.out.println("Reading 7-zip...");
    SevenZFile sevenZFile = new SevenZFile(sevenz);
    long s = System.currentTimeMillis();
    SevenZArchiveEntry entry;
    while((entry=sevenZFile.getNextEntry())!=null){
        System.out.print(entry.isDirectory()?"Dir":"File");
        System.out.print("\t");
        System.out.print("*********.***"); //entry.getName();
        System.out.print("\t");
        System.out.println(entry.getHasCrc()?"CRC":"NO-CRC");
    }
    System.out.println("------------------------------");
    System.out.println("7-zip\t"+(System.currentTimeMillis()-s)+" ms to read.");

}   

输出是:

Reading 7-zip...
File    *********.***   CRC
File    *********.***   CRC
File    *********.***   CRC
File    *********.***   CRC
File    *********.***   CRC
------------------------------
7-zip   6236 ms to read.

文件列表过程应该花费所有时间还是我做错了什么?我还尝试删除所有打印件,但读取文件所需的时间是相同的。

4

1 回答 1

1

这似乎有点偏高。我要做的第一件事就是消除多余的努力,只花时间阅读阅读部分。

这意味着注释掉System.out.println循环内的所有命令:

while ((entry = sevenZFile.getNextEntry()) != null) {
}
System.out.println("total\t" + (System.currentTimeMillis()-s) + " ms.");

这样做,看看它是否有所作为。这将告诉您是条目扫描本身还是打印和/或从每个条目中提取数据。

除此之外,您还可以了解每次迭代需要多长时间:

while ((entry = sevenZFile.getNextEntry()) != null) {
    long s2 = System.currentTimeMillis();
    System.out.println("entry\t" + (s2-s) + " ms.");
    s = s2;
}

我有一个模糊的回忆,Apache Commons Compress 在启动时读取了整个条目列表,并且根据此处的源代码似乎就是这种情况。

一种可能性是获取该源代码,将其暂时按原样合并到您自己的代码中,然后对其进行分析以查看它在实例化过程中大部分时间花费在哪里。

于 2014-10-09T08:10:07.160 回答