- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在 jimfs 中创建了一个 zip 文件(内存文件系统中的谷歌)来自字节数组。尝试使用 ZipMemoryFileSystem
打开该文件时,我收到无法识别提供者的错误。我的代码如下:
public static void test(byte[] document) {
try {
try (FileSystem memoryFileSystem = Jimfs.newFileSystem(Configuration.unix())) {
Files.write(memoryFileSystem.getPath("/file.zip"), document);
URI uri = URI.create("jar:" + memoryFileSystem.getPath("/file.zip").toUri());
Map<String, String> env = Collections.singletonMap("create", "false");
try (FileSystem zipfs = FileSystems.newFileSystem(uri, env)) {
//do something
} catch (Exception e) {
e.printStackTrace();
}
}
} catch (IOException e) {
e.printStackTrace();
}
}
URI 类似于:jar:jimfs://bb2c779f-d327-4e2f-9841-bd04785f1365/file.zip
.
堆栈跟踪是:
java.nio.file.FileSystemNotFoundException: Provider "jimfs" not installed
at java.nio.file.Paths.get(Paths.java:158)
at com.sun.nio.zipfs.ZipFileSystemProvider.uriToPath(ZipFileSystemProvider.java:97)
at com.sun.nio.zipfs.ZipFileSystemProvider.newFileSystem(ZipFileSystemProvider.java:119)
at java.nio.file.FileSystems.newFileSystem(FileSystems.java:337)
at java.nio.file.FileSystems.newFileSystem(FileSystems.java:287)
at office.ImfsTest.test(ImfsTest.java:88)
at office.ImfsTest.main(ImfsTest.java:58)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:95)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:55)
at java.lang.reflect.Method.invoke(Method.java:508)
at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:293)
at java.lang.Thread.run(Thread.java:785)
jimfs 未与 FileSystemProvider.installedProviders()
一起列出.它位于与 ZipFileSystemProvider
不同的类加载器中,分别Thread.currentThread().getContextClassLoader()
与 ClassLoader.getSystemClassLoader().getParent()
对于 FileSystemZipProvider
.
供应商打印如下:
IM Provider:com.google.common.jimfs.JimfsFileSystemProvider@ed301b1f IM Scheme:jimfs IM Class Loader:java.net.URLClassLoader@4940e7a2
Installed Provider:sun.nio.fs.LinuxFileSystemProvider@d83a6d85 Scheme:file Class Loader:null
Installed Provider:com.sun.nio.zipfs.ZipFileSystemProvider@110a4ec7 Scheme:jar Class Loader:sun.misc.Launcher$ExtClassLoader@59a155ab
我尝试基于 jimfs 手动设置类加载器 ClassLoaderTest没有成功的例子。 我在 Linux 上运行。
使用 jimfs 1.1(也尝试使用 2.0-SNAPSHOT 修复 https://github.com/google/jimfs/commit/3299e69f75cf524e6d101d88e8c202c1b24bf25a 问题 31)。
如何让我的代码正常工作?
最佳答案
解决方案:
基于 SO 问题 How to register a SPI implementation when running exec:java ,我知道类加载器问题是由于代码是使用 maven exec:java 运行的。使用普通 jar 运行代码解决了问题!
关于java - ZipFileSystemProvider 无法识别 JIMFS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37603205/
我开始使用 google jimfs,但我不明白如何从路径获取文件。在源代码中,我看到 Path.toFile 抛出 UnsupportedOperationException。但是没有文件我怎么能使
我有一个特定的用例,将普通文件系统抽象为内存文件系统对我有好处,因为我们经常出于性能原因在两者之间切换。JIMFS 可以在生产环境中使用还是纯粹用于测试? 最佳答案 没有什么特别的原因它不能用于生产。
我已经使用 JIMFS 创建了一个 VFS。 FileSystem virtualFS = Jimfs.newFileSystem(Configuration.unix()); Path virtua
我开始使用 google jimfs 并执行 ls 我发现在 FS 的根目录中有工作目录。这个文件夹的用途是什么? 最佳答案 它只是一个任意目录,因此工作目录(相对路径解析所依据的目录)不是根目录,因
我在测试中使用 Jimfs,如下所示: public class FooTest { private FileSystem fs = Jimfs.newFileSystem(Configurati
我在 jimfs 中创建了一个 zip 文件(内存文件系统中的谷歌)来自字节数组。尝试使用 ZipMemoryFileSystem 打开该文件时,我收到无法识别提供者的错误。我的代码如下: publi
我想使用 Google 的 JIMFS 创建一个用于测试的虚拟文件系统。不过,我很难开始。 我看了这个教程:http://www.hascode.com/2015/03/creating-in-mem
我正在尝试在 Jimfs 文件系统中创建一个目录(使用 Ceylon 的文件模块),但是当从 Ceylon 访问文件系统时,我遇到了 Jimfs 提供程序未安装的问题。 这是我的测试程序: // Fi
我有文件相关的代码来测试我想在哪里测试我无法读取的现有文件的错误处理。 class SomeClass { //... public void load(Path path) {
如何使用 jimfs 设置文件的最后修改日期?我有……像这样: final FileSystem fileSystem = Jimfs.newFileSystem(Configuration.unix
我是一名优秀的程序员,十分优秀!