(defn float-seqs [#^java.io.DataInputStream dis]
(lazy-seq
(try
(cons (.readFloat dis) (float-seqs dis))
(catch java.io.EOFException e
(.close dis)))))
(with-open [dis (-> file java.io.FileInputStream. java.io.DataInputStream.)]
(let [s (float-seqs dis)]
(doseq [f s]
(println f))))
Вы не обязаны использовать with-open, если уверены, что собираетесь использовать весь seq.
Если вы используете with-open, дважды проверьте, что вы не пропускаете seq (или производный seq) вне его области действия.