我试图从我的jar中提取一个文件并将其复制到temp
目录中。 要读取jar文件中的文件,我正在使用DataInputStream
将文件写入临时目录,我正在使用DataOutputStream
。为什么我的DataInputStream只读取114个字节?
我试图提取的文件的文件大小为310千字节,在我调用我的方法(这也是我的方法打印到控制台的字节数)后,我的复制文件仅包含114个字节。
这里是我的方法:
private static void extractFile(String pathInJar, String fileToCopy) {
File outputFile = new File(System.getProperty("java.io.tmpdir") + "/LDEngine/"+fileToCopy);
boolean couldDirsBeCreated = outputFile.getParentFile().mkdirs();
if(couldDirsBeCreated && !outputFile.exists()) {
int x;
int actualBytesRead = 0;
byte[] tmpByteArray = new byte[4096];
try(
DataOutputStream output = new DataOutputStream(new FileOutputStream(outputFile));
DataInputStream in = new DataInputStream(LibLoader.class.getResourceAsStream("/libs/natives/"+pathInJar))
){
while((x=in.read(tmpByteArray)) != -1) {
output.write(tmpByteArray);
actualBytesRead += x;
}
} catch(Exception e) {
System.err.println("Fatal error: Could not write file!");
System.exit(1);
}
System.out.println(actualBytesRead);
}
}
我试图复制该文件是一个.dll
,所以这是我处理的二进制数据。
问题是为什么会发生这种情况,我做错了什么?
只是个头:有许多经过充分测试的库(如Google Guava),其功能与您所做的完全相同。例如。 'Resources.copy(Resources.getResource(SomeRef.class,“/dir/SomeResource.txt”),someOutputStream);'。这最大限度地减少了代码和测试“开销”。祝你的项目好运。 – Brian