2

有一个小程序在 TrueZip 6 上运行良好。最近我通过在项目的类路径中添加 6 个包将 TrueZip jar 更新到版本 7.7.9:truezip-driver-file、truezip-driver-tar、truezip-driver-zip 、truezip-file、truezip-kernel 和 truezip-swing以及所有必要的依赖项(xz 1.5 等)。

编译过程中没有错误,但是,当我尝试在 main 方法中运行时:

TConfig.get().setArchiveDetector(
    new TArchiveDetector(TArchiveDetector.NULL, new Object[][] {
        { "tar", new TarDriver(IOPoolLocator.SINGLETON) },
        { "tgz|tar.gz", new TarGZipDriver(IOPoolLocator.SINGLETON) },
        { "zip|alt|alib", new ZipDrive(IOPoolLocator.SINGLETON) } })); 

它显示de.schlichtherle.truezip.socket.sl.IOPoolLocator$Boot 无法在 IOPoolLocator 中实例化

Boot 是一个内部和静态的最终类 http://grepcode.com/file/repo1.maven.org/maven2/de.schlichtherle.truezip/truezip-kernel/7.7.9/de/schlichtherle/truezip/socket/sl/ IOPoolLocator.java#IOPoolLocator

我发现很少有参考资料,但不幸的是不是很有帮助。

4

1 回答 1

1

我有同样的问题,我猜你是在单独的行中添加这些 TrueZip 类路径条目?

在这种情况下,我的解决方案是:将它们添加到一行中,路径用逗号“,”分隔

尝试深入调试 JVM 中 Boot 类的第一个实例化的真正错误:

static final IOPool<?> pool;
static {
    final Class<?> clazz = IOPoolLocator.class;
    final Logger logger = Logger.getLogger(clazz.getName(), clazz.getName());
    final ServiceLocator locator = new ServiceLocator(clazz.getClassLoader());
    pool = decorate((IOPool) create(locator, logger), locator, logger);
}

你会看到最后它转到了后面异常的来源:

this.l1 = null != loader ? loader : ClassLoader.getSystemClassLoader();

基本上它使用的是 ServiceLoader 或 ClassLoader。现在在 main 方法中执行测试:

aClassLoader.getResourceAsStream("/META-INF/services/de.schlichtherle.truezip.socket.spi.IOPoolService") 

使用 6 个 jar 文件中的每一个中包含的不同类,您应该会看到只有 truezip-kernel.jar 中的类可以找到 IOPoolService,因为所有 jar 文件都是由不同的加载器加载的(不是相同的对象 ID)。

于 2015-08-20T12:33:36.103 回答