如何在Clojure中正确读取RandomAccessFile?

如何在Clojure中正确读取RandomAccessFile?,clojure,random-access,Clojure,Random Access,我一直在尝试开发一个用于在Clojure中读取MPQ文件的小库,我决定使用RandomAccessFile,因为MPQ是一种二进制格式 但是,我在使用方法RandomAccessFile#read()时遇到了问题,因为我不确定是否正确调用了它 代码如下: (ns parser (:import (java.io RandomAccessFile))) (with-open [file (RandomAccessFile. "replay.SC2Replay" "r")] (let [

我一直在尝试开发一个用于在Clojure中读取MPQ文件的小库,我决定使用RandomAccessFile,因为MPQ是一种二进制格式

但是,我在使用方法
RandomAccessFile#read()
时遇到了问题,因为我不确定是否正确调用了它

代码如下:

(ns parser
  (:import (java.io RandomAccessFile)))


(with-open [file (RandomAccessFile. "replay.SC2Replay" "r")]
  (let [x (byte-array 16)]
    (.read file [x 0 16])))
当我运行代码时,我得到

Exception in thread "main" java.lang.ClassCastException: clojure.lang.PersistentVector cannot be cast to [B (parser.clj:0)
    at clojure.lang.Compiler.eval(Compiler.java:5440)
    at clojure.lang.Compiler.load(Compiler.java:5857)
    at clojure.lang.Compiler.loadFile(Compiler.java:5820)
    at clojure.main$load_script.invoke(main.clj:221)
    at clojure.main$script_opt.invoke(main.clj:273)
    at clojure.main$main.doInvoke(main.clj:354)
    at clojure.lang.RestFn.invoke(RestFn.java:409)
    at clojure.lang.Var.invoke(Var.java:365)
    at clojure.lang.AFn.applyToHelper(AFn.java:163)
    at clojure.lang.Var.applyTo(Var.java:482)
    at clojure.main.main(main.java:37)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
Caused by: java.lang.ClassCastException: clojure.lang.PersistentVector cannot be cast to [B
    at parser$eval7.invoke(parser.clj:7)
    at clojure.lang.Compiler.eval(Compiler.java:5424)
    ... 15 more
例外。我还尝试对临时变量执行此操作

(let [x []]
但这两者都产生了相同的例外。Java中的相同代码应该是这样的

RandomAccessFile file = new RandomAccessFile("replay.SC2Replay", "r");
byte[] x;
file.read(x, 0, 16);

您将传入一个向量作为参数,它试图将其转换为字节数组,以便调用接收字节数组的单参数读取方法。只需按原样传递参数

(with-open [file (RandomAccessFile. "replay.SC2Replay" "r")]
  (let [x (byte-array 16)]
    (.read file x 0 16)))